Problem E: 零起点学算法34——3n+1问题

#include<stdio.h>
#include<math.h>
int main()
{
    int n;
    n<=pow(10,9);
    int count=0;
    scanf("%d",&n);
    while(n!=1)
    {
        count++;
        if(n%2==0)
        n=n/2;
        else
        n=n*3+1;
    }
    printf("%d\n",count);
    return 0;
}

HINT

 

使用 while 循环使用 while 语句在条件成立时重复某动作,类似于 if 语句,只要条件为 true 就重复动作。 while 循环计算一个表达式的值,如果表达式为 true,则会执行循环体中的代码。如果条件计算结果为 true,在循环返回以再次计算条件前执行一条语句或一系列语句。条件计算结果为 false 后,则跳过语句或一系列语句并结束循环。在不确定要将一个代码块循环多少次时,使用 while 循环可能会非常有用。 例如,下面的代码将数字显示到"输出"面板中: var i:Number = 0; while (i < 5) { trace(i); i++; } 您会看到以下数字显示到"输出"面板中: 0 1 2 3 4 使用 while 循环而非 for 循环的一个缺点是,在 while 循环中更有可能编写出无限循环。如果遗漏递增计数器变量的表达式,则 for 循环示例代码将无法编译;而 while 循环示例代码将能够编译。若没有递增 i 的表达式,循环将成为无限循环。

 



posted @ 2018-11-19 15:45  MichaelCecil  阅读(1009)  评论(0编辑  收藏  举报