我爱橙 发表于 2022-6-11 23:52:36

EX4.22+4+5 计算k以内最大的10个能被13或17整除的自然数之和

本帖最后由 我爱橙 于 2022-6-12 00:02 编辑

编写程序计算k以内最大的10个能被13或17整除的自然数之和。

输入格式:
"%d"

输出格式:
"%d\n"

输入样例:
在这里给出一组输入。例如:

300
输出样例:
在这里给出相应的输出。例如:

2653

#include <stdio.h>

int main( )
{
int i,k,sum=0;
scanf("%d",&k);
for(i=1;i<=k;i++)
{
        if(i%13==0||i%17==0)
    sum+=i;
}
printf("%d\n",sum);
return 0;
}


算出来了所有的,怎么求最大的10个啊?


网上找了个答案:
#include<stdio.h>
int main(void)
{
int k,i=0,sum=0;
printf("Please Input k:\n");
scanf("%d",&k);
while(k>=0&&i<10)
{
   if(k%13==0||k%17==0)
   {
   sum+=k;
   i++;
    }
   k--;
}
printf("The sum is %d\n",sum);
}

临时号 发表于 2022-6-12 00:15:23

本帖最后由 临时号 于 2022-6-17 00:47 编辑

我的思路是:从k开始找,往后找10个符合条件的数,把他们分别加起来
#include <stdio.h>

int main()
{
        int k;
        int i;
        int sum = 0;
        int count = 0;
       
        scanf("%d",&k);
       
        for (i=k;i>0;i--)
        {
                if (i%13==0||i%17==0)
                {
                        if (count!=10)
                        {
                                sum += i;
                                count++;
                        }
                }
        }
        printf("%d\n",sum);
        return 0;
}

风车呼呼呼 发表于 2022-6-12 00:16:50

从大到小遍历,前10个符合要求的不就是最大的吗。你网上找的就是这思路,有什么问题

临时号 发表于 2022-6-12 00:18:23

风车呼呼呼 发表于 2022-6-12 00:16
从大到小遍历,前10个符合要求的不就是最大的吗。你网上找的就是这思路,有什么问题

我用的是网上的思路,楼主用的是他自己的思路

风车呼呼呼 发表于 2022-6-12 00:29:18

临时号 发表于 2022-6-12 00:18
我用的是网上的思路,楼主用的是他自己的思路

楼主自己没思路,他自己求的是所有符合数之和。你写的和楼主贴网上找的那个思路一致,我是不太明白楼主都自己找到了符合的代码,他是想要问什么

我爱橙 发表于 2022-6-12 00:38:41

风车呼呼呼 发表于 2022-6-12 00:29
楼主自己没思路,他自己求的是所有符合数之和。你写的和楼主贴网上找的那个思路一致,我是不太明白楼主都 ...

因为没看懂啊{:9_222:}

风车呼呼呼 发表于 2022-6-12 00:45:54

我爱橙 发表于 2022-6-12 00:38
因为没看懂啊

那…思路已经说了,k就是题目的那个k,i是一个计数器,加满10个就终止。没道理看不懂吧

临时号 发表于 2022-6-12 00:48:25

本帖最后由 临时号 于 2022-6-12 00:49 编辑

我爱橙 发表于 2022-6-12 00:38
因为没看懂啊

我说的思路应该很清晰吧
从k开始找,往后找10个符合条件的数,把他们分别加起来
页: [1]
查看完整版本: EX4.22+4+5 计算k以内最大的10个能被13或17整除的自然数之和