[C语言]程序改错题。爱因斯坦曾出过这样的一道数学题:有一条长阶梯,若每步跨2阶,最后剩下1阶;若每步跨3阶,最后剩下2阶;若每步跨5阶,最后剩下4阶;若每步跨6阶,最后剩下5阶;只有每步跨7阶...

程序改错题。爱因斯坦曾出过这样的一道数学题:有一条长阶梯,若每步跨2阶,最后剩下1阶;若每步跨3阶,最后剩下2阶;若每步跨5阶,最后剩下4阶;若每步跨6阶,最后剩下5阶;只有每步跨7阶,最后才正好1阶不剩下。
   编写计算这条阶梯共有多少阶的程序如下所示,其中存在一些语法和逻辑错误,请找出并改正之。

#include <stdio.h>
int main()
{
   int x = 1, find = 0;
   while (!find);
   {
      if (x % 2 == 1 && x % 3 == 2 && x % 5 == 4 && x % 6 == 5 && x % 7 = 0)
      {
         printf("x = %d\n", x);
         find = 1;
         x++;
      }
   }
   return 0;
}

1.语法错误:while(){}为标准格式,这里后面多了; 显然错误

2.语法错误:x%7=0改为x%7==0 (赋值运算符和关系运算符的差距)

3.逻辑错误:x++不应该包含在正确的判断的分支里面,x++的用处为在此分支判断为否的情况下继续按照循环顺序依次穷举,所以x++应该在if分支之外

综上,修改完成的正确代码应该为:

#include <stdio.h>
int main()
{
   int x = 1, find = 0;
   while (!find)
   {
      if (x % 2 == 1 && x % 3 == 2 && x % 5 == 4 && x % 6 == 5 && x % 7 == 0)
      {
         printf("x = %d\n", x);
         find = 1;
      }
      x++;
   }
   return 0;
}

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一道关于同余方程的学问题。可以使用中国剩余定理来解决。 首先根据题意,可以列出如下同余方程组: ``` x ≡ 1 (mod 2) x ≡ 2 (mod 3) x ≡ 4 (mod 5) x ≡ 5 (mod 6) x ≡ 0 (mod 7) ``` 可以使用逐步推导的方法求解。 首先考虑第一步,根据第一个同余方程,可以列出: ``` x = 2k + 1 ``` 其中 k 为整。 将其代入第二个同余方程,得到: ``` 2k + 1 ≡ 2 (mod 3) ``` 化简后得到: ``` k ≡ 1 (mod 3) ``` 代入第三个同余方程,得到: ``` x = 6m + 2 ``` 其中 m 为整。 代入第四个同余方程,得到: ``` 6m + 2 ≡ 5 (mod 6) ``` 化简后得到: ``` m ≡ 3 (mod 6) ``` 代入第五个同余方程,得到: ``` x = 42n ``` 其中 n 为整。 将其代入第一个同余方程,得到: ``` 42n ≡ 1 (mod 2) ``` 化简后得到: ``` n ≡ 1 (mod 2) ``` 综合以上结果,可以得到: ``` x = 420t + 301 ``` 其中 t 为整。 因为最后一步7,所以 x 必须满足: ``` x ≡ 0 (mod 7) ``` 代入上式,得到: ``` 420t + 301 ≡ 0 (mod 7) ``` 化简后得到: ``` t ≡ 5 (mod 7) ``` 综合以上结果,可以得到: ``` x = 420 * 5 * k + 301 = 2101 + 2100k ``` 其中 k 为整。 因为需要是正整,所以最终的答案为: ``` x = 2101 + 2100k,其中 k 为正整。 ``` 因为题目中要求最后才正好一不剩,所以可以得到: ``` x = 2101 + 2100 = 4201 ``` 所以这条阶梯共有 4201

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值