算法:POJ1006 三重峰值问题

简介: 这题有直接套公式的解法 这里提供一个O(n)的解法。 package practice; import java.io.BufferedInputStream; import java.

这题有直接套公式的解法

这里提供一个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.");
        }

    }
}

 

目录
相关文章
|
5天前
|
算法
【算法】二分算法——寻找峰值
【算法】二分算法——寻找峰值
|
3月前
|
算法 程序员
【算法训练-二分查找 三】【特殊二分】寻找峰值
【算法训练-二分查找 三】【特殊二分】寻找峰值
45 0
|
10月前
|
算法 索引
|
3月前
|
存储 算法 搜索推荐
C语言第二十九练 三分算法求峰值
C语言第二十九练 三分算法求峰值
56 1
|
3月前
|
算法 JavaScript 索引
|
8月前
|
算法 测试技术 C#
C++二分算法的应用:寻找峰值原理、源码及测试用例
C++二分算法的应用:寻找峰值原理、源码及测试用例
|
3月前
|
算法 vr&ar 图形学
☆打卡算法☆LeetCode 162. 寻找峰值 算法解析
☆打卡算法☆LeetCode 162. 寻找峰值 算法解析
|
机器学习/深度学习 算法
【MATLAB第25期】基于MATLAB的LSTM深度学习模型的自动检测时间序列数据峰值算法
【MATLAB第25期】基于MATLAB的LSTM深度学习模型的自动检测时间序列数据峰值算法
|
存储 算法 前端开发
前端算法-查找峰值
前端算法-查找峰值
|
算法 索引
数据结构与算法之数组寻找峰值&&分而治之
数据结构与算法之数组寻找峰值&&分而治之
163 0
数据结构与算法之数组寻找峰值&&分而治之

热门文章

最新文章