标题:
角谷定理
类别:
时间限制:
2 S
内存限制:
10000 Kb
问题描述:
角谷定理定义如下:
对于一个大于1的整数n,如果n是偶数,则n = n / 2。如果n是奇数,则n = 3 * n +1,反复操作后,n一定为1。
例如输入22的变化过程: 22 ->11 -> 34 -> 17 -> 52 -> 26 -> 13 -> 40 -> 20 -> 10 -> 5 -> 16 -> 8 -> 4 -> 2 -> 1,数据变化次数为15。
输入一个大于1的整数,求经过多少次变化可得到自然数1。
输入说明
输入为一个整数n,1
输出说明
输出变为1需要的次数
输入样例
样例1输入
22
样例2输入
33
输出样例
样例1输出
15
样例2输出
26
我的代码
int main()
{
int n;
int sum = 0;
scanf("%d", &n);
p:
if(n % 2 == 0)
{
n = n/2;
sum = sum+1;
if(n = 1) goto m;
else goto p;
}
if(n%2!=0)
{
n = n*3+1;
sum = sum+1;
if(n = 1) goto m;
else goto p;
}
m:
printf("%d", sum);
}
if判断错了,判断n是否等于1,if里面两个等号
第7行和16行,你把n赋值为1了
CSDN有BUG,你的代码贴的错乱了
#include <stdio.h>
int main() {
int n, sum = 0;
scanf("%d", &n);
if (n > 1) {
while (n > 1) {
if (n % 2 == 0) {
n = n / 2;
} else {
n = 3 * n + 1;
}
sum++;
}
printf("需要%d次\n",sum);
} else {
printf("输入错误");
}
return 0;
}