爱因斯坦的数学题(C语言)

题目描述:

 爱因斯坦出了一道这样的数学题:有一条长阶梯,若每步跨2阶,则最后剩一阶,若每步跨3 阶,则最后剩2阶,若每步跨5阶,则最后剩4阶,若每步跨6阶则最后剩5阶。只有每次跨7阶,最后才正好一阶不剩。请问在1到N内,有多少个数能满足?

 输入:

有多组数据,每一行只有一个n。

 输出:

输出满足条件的个数。每个答案一行。

 样例输入 :

1999999

 样例输出:

9524

源代码:

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main(void)
{
    int n,i;
    int count;
    while(scanf("%d",&n)==1)
    {
        count=0;
        for(i=7; i<=n; i++)
        {
            if(i%2==1&&i%3==2&&i%5==4&&i%6==5&&i%7==0)
                count++;
        }
        printf("%d\n",count);
    }
    return 0;

}

 解题思路:

从键盘输入n,将count赋值0。进入循环,判断从7到n是否有满足题目条件的变量,若满足则count加一并继续循环,否则直接继续循环。最后输出count。

算法步骤:

  1. 输入一个数,将它赋给n

  2. 将count赋值为0

  3. 进入循环,从7开始一直到n。判断i是否对2取余等于1且对3取余等于2且对5取余等于4且对6取余等于5且对7取余等于0

  4. 若是,则count加一并继续循环

  5. 否则直接继续循环

  6. 输出count的值

 遇到的问题:

遇到的问题:因为有多组数据,没有把count重新赋值0导致错误

解决的办法:将count=0移入while循环中

  • 1
    点赞
  • 12
    收藏
  • 打赏
    打赏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:数字20 设计师:CSDN官方博客 返回首页
评论

打赏作者

沐林天释

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值