7-254 静态局部变量(程序举例)

任务描述

3n+1猜想是当今最简单有趣又没有解决的数学问题之一,指的是对于每一个正整数,如果它是奇数,则对它乘 3 再加 1,如果它是偶数,则对它除以 2,如此循环,最终都能够得到 1。

请设计函数long next(long n){ },返回3n+1猜想中形式参数n的下一个值。例如:next(5)的值为16、next(16)的值为8等等。
主函数的功能为读入一个整数n,输出变换到1的过程。

#include<stdio.h>
long next(long n){
    //请补充代码
}
int main(){
    long n;
    scanf("%ld",&n);
    while(n!=1){ 
      n=next(n);
    }
    return 0;
}

输入样例:

5

输出样例:

Times of 1 is 16.
Times of 2 is 8.
Times of 3 is 4.
Times of 4 is 2.
Times of 5 is 1.

输入样例:

7

输出样例:

Times of 1 is 22.
Times of 2 is 11.
Times of 3 is 34.
Times of 4 is 17.
Times of 5 is 52.
Times of 6 is 26.
Times of 7 is 13.
Times of 8 is 40.
Times of 9 is 20.
Times of 10 is 10.
Times of 11 is 5.
Times of 12 is 16.
Times of 13 is 8.
Times of 14 is 4.
Times of 15 is 2.
Times of 16 is 1.

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

思路

本题是一道代码补全题。本题要求使用静态局部变量,因此在定义计数器变量时要使用static。代码补全部分是计算。如果n为偶数,那么n/=2;如果n为奇数,n=n*3+1;注意其输出格式。7-255题干中有问题的答案。

代码

#include<stdio.h>
long next(long n){
    static long i=0;
    i++;
    if(n%2!=0)
    {
        n=n*3+1;
    }
    else
        n/=2;
    printf("Times of %ld is %ld.\n",i,n);
    return n;
}
int main(){
    long n;
    scanf("%ld",&n);
    while(n!=1){ 
      n=next(n);
    }
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吾乃宇宙欠债王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值