对于任意大于1的自然数n,若n为奇数,则将n变为3n+1,否则变为n的一半。
经过若干次这样的变换,一定会使n变为1。例如,3→10→5→16→8→4→2→1。
输入n,输出变换的次数。n≤10^9 。
样例输入:
3
样例输出:
7
对于以下程序,由于int类型一般是2^32范围,所以中间值
n*3是可能溢出的,造成程序错误。
#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;
}
解决方法:
输入输出使用int类型的n2,然后中间值用longlong n来代替,
以避免longlong类型输入输出不同平台的不同规定
#include<stdio.h>
int main()
{
int n2, count = 0;
scanf("%d", &n2);
long long n = n2;
while(n > 1)
{
if(n % 2 == 1) n = n*3+1;
else n /= 2;
count++;
}
printf("%d\n", count);
return 0;
}