问题描述:日本一位中学生发现一个奇妙的“定理”,请角谷教授证明,而教授无能为力,于是产生角谷猜想。猜想的内容是:任给一个自然数,若为偶数除以2,若为奇数则乘3加1,得到一个新的自然数后按照上面的法则继续演算,若干次后得到的结果必然为1。请编程验证。
标准输入:10
标准输出:
10/2=5 5*3+1=16 16/2=8 8/2=4 4/2=2 2/2=1
该题主要考察在循环结构中的if语句的使用,问题本身不难,只是在处理输出答案的时候比较麻烦。
首先分析题目,我们得知在输出结果最后为0的时候应结束循环,便可使用while(n>1)来作为我们的循环条件。随后进行输入数的奇偶判断进行不同的处理,最后输出答案即可。
#include<stdio.h>
int main()
{
int n;
scanf("%d", &n);
while (n > 1)
{
if (n % 2 == 0)
{
printf("%d/2=", n);//应先打印未进行处理的n后对于n进行特殊处理以达到特殊的输出要求
n = n / 2;
printf("%d", n);
}
else if (n % 2 != 0)
{
printf("%d*3+1=", n);//此处原理与上相同
n = n * 3 + 1;
printf("%d", n);
}
printf("\n");//进行换行
}
return 0;
}