1001 害死人不偿命的(3n+1)猜想 (15分)

时间:2020-07-11
本文章向大家介绍1001 害死人不偿命的(3n+1)猜想 (15分),主要包括1001 害死人不偿命的(3n+1)猜想 (15分)使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1001 害死人不偿命的(3n+1)猜想 

写后总结:数字与字母相乘,乘法不能省略;注意局部变量的位置;别光写算法,把"输出"忘记写.



这是一个部分正确的,原因是什么?


#include<iostream> using namespace std; int main() { //int max=1000; int a; cin>>a; int sum; for(sum=0;a!=1;sum++) { if(a%2==1)//是这里 a=a/2; else a=(3*a+1)/2; } cout<<sum; return 0; }





正确代码1:
#include<cstdio> int main() { int n,count=0; scanf("%d",&n); while(n!=1) { if(n%2==0) n=n/2; else n=(3*n+1)/2; count++; } printf("%d",count); return 0; }


正确代码2:

#include<iostream> using namespace std; int main() { int a; cin>>a; int sum=0; for(;a!=1;sum++) { if(a%2==0) a=a/2; else a=(3*a+1)/2; } cout<<sum; return 0; }

原文地址:https://www.cnblogs.com/leamant/p/13285670.html