例:3n+1问题
对于任意大于1的自然数n,若n为奇数,则将n变为3n+1,否则变为n的一半。经过若干次变换,一定会使n变为1。例如3-》10-》5-》16-》8-》4-》2-》1。
输入n,输出变换的次数。n不大于10的九次幂。
样例输入:3
样例输出:7
解:直接模拟过程即可,下面是代码:
#include<stdio.h>
int main()
{
int n, count = 0;
scanf("%d", &n);
while(n > 1)
{
if(n%2 == 1) n = n * 3 + 1;
else n /= 2;
count++;
}
printf("%d\n", count);
return 0;
}
验证上面样例,发现正确:
那如果输入的是999999999呢?结果: