java实现角谷猜想
java实现角谷猜想
最近正在重新学习JAVA,想证明在3-10000内所有的正整数都符合角谷猜想,于是写了如下代码(错误代码,请勿尝试)
package test1;
public class guess {
public static void main(String ags[]) {
int count=0;//count变量记录符合个数
for(int i=3 ; i<=10000 ; i++){ //简单的for循环
while(i!=1) {
//while循环:当i不等于1时,执行以下代码
i=(i%2==0? i/2:i*3+1);
//该代码运用了三元条件运算符,相当于使用了if-else语句 if i%2==0 i=i/2,else i=i*3+1
}
// 跳出循环相当于i=1,符合角谷猜想,count+1
count++;
System.out.printf("3-10000内有"+count+"个数符合\n");
}}}
执行结果如下
发现变成了一个死循环,并不符合预期,于是查询了一些资料。
错误原因:以上代码中的i对应的是同一个物理地址,当while循环中的i改变时,for循环中的i也会跟着改变,所以在第一遍