POJ 1006 Biorhythms
POJ 1003,1004,1005 比较简单,很快就解决了。有个小插曲,刚开始做ACM不太懂,最近提交问题反馈最多的就是Runtime Error,开始我以为是超时,1方面我怀疑是否是Java跑得太慢了,然后去了解发现有些国际大赛推荐用java,那说明java本身是不慢的。另外一方面我怀疑是我程序太烂,每次都很耗时,所以每次遇到Runtime Error问题就去优化代码,但有时候怎样优化都不行。在做POJ1005的时候,网上的代码贴上去AC了,但是我的不行,但两个程序已完全1样了,这个时候才发现罪魁罪魁是我提交时总是带着包名(有时候手动是去了的)。
POJ 1006这个题目我虽然能提交通过,但我的方法更多的算暴力破解。 import java.util.Scanner;
public class Main {
public static void main(String[] args){
Scanner scanner = new Scanner(System.in);
for(int j=1; j<Integer.MAX_VALUE; j++){
int p = scanner.nextInt() % 23;
int e = scanner.nextInt() % 28;
int i = scanner.nextInt() % 33;
int d = scanner.nextInt();
if(p==⑴ && e==⑴ && i==⑴ && d==⑴) return;
for(int number=0; number<=21252+d; ){
if(p == number % 23){
if(e == number % 28){
if(i == number % 33) {
if (number-d <= 0)
number += 21252;
System.out.println("Case "+j+": the next triple peak occurs in "+ (number-d) +" days.");
break;
} else
number += 23*28;
} else
number += 23;
} else
number ++;
}
}
}
}
解题的关键是从复杂错乱的描写中抽象出问题的本质,也就是将现象转化为数学问题。POJ1006这个问题的难点是背后的数学问题――中国剩余定理。 1个数除3余2,除5余3,除7余2。可以用初等数论中的同余方程组来求解,利用同余的符号,可以将上述问题转化为下面的同余方程组:
回到POJ1006这个题目,已知number % 23 = p,number % 28 = e,number % 33 = i (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |