码迷,mamicode.com
首页 > 编程语言 > 详细

算法:POJ1006 三重峰值问题

时间:2014-11-05 12:56:22      阅读:225      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   color   ar   java   sp   div   2014   

这题有直接套公式的解法

这里提供一个O(n)的解法。

package practice;

import java.io.BufferedInputStream;
import java.util.Scanner;

/**
 * 
 * 
 * @author caiyu
 * @date 2014-11-4
 */
public class POJ1006 {
    public static void main(String[] args) {
        Scanner cin = new Scanner(new BufferedInputStream(System.in));
        while (true) {
            int p = cin.nextInt();
            if (p < 0)
                break;
            int e = cin.nextInt();
            if (e < 0)
                break;
            int i = cin.nextInt();
            if (i < 0)
                break;
            int d = cin.nextInt();
            if (d < 0)
                break;
            int x = 1, y = 1, z = 1;
            int ty = 0, tx = 0, tz = 0;
            boolean fx = true, fy = true, fz = true;
            int temp = 0;
            while (true) {

                if (fy) {
                    if (ty < 21252)
                        ty = e + 28 * y++ - d;
                    else
                        break;
                    if ((ty - p + d) % 23 == 0) {
                        if (ty > temp) {
                            temp = ty;
                            fz = true;
                            fx = true;
                            fy = false;
                        } else if (ty == temp) {
                            fy = false;
                        }
                    }
                }

                if (fz) {
                    if (tz < 21252)
                        tz = i + 33 * z++ - d;
                    else
                        break;
                    if ((tz - p + d) % 23 == 0) {
                        if (tz > temp) {
                            temp = tz;
                            fx = true;
                            fy = true;
                            fz = false;
                        } else if (tz == temp) {
                            fz = false;
                        }
                    }
                }

                if (fx) {
                    if (tx < 21252)
                        tx = p + 23 * x++ - d;
                    else
                        break;
                    if ((tx - e + d) % 28 == 0) {
                        if (tx > temp) {
                            temp = tx;
                            fy = true;
                            fz = true;
                            fx = false;
                        } else if (tx == temp) {
                            fx = false;
                        }
                    }
                }
                if (!fx && !fy && !fz)
                    break;

            }

            System.out.println("Case 1: the next triple peak occurs in " + temp
                    + " days.");
        }

    }
}

 

算法:POJ1006 三重峰值问题

标签:style   blog   io   color   ar   java   sp   div   2014   

原文地址:http://www.cnblogs.com/anrainie/p/4075861.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!