C语言 想问问哪里错了呀

题目: 编写函数,要求计算并输出不超过n的最大的k个素数以及它们的和。注意找到的k个素数先要保存在数组a中。输入格式: 输入在一行中给出n(10≤n≤10000)和k(1≤k≤10)的值。输出格式: 在一行中按下列格式输出: 素数1+素数2+…+素数k=总和值 其中素数按递减顺序输出。若n以内不够k个素数,则按实际个数输出。输入样例1: 1000 10输出样例1: 997+991+983+977+971+967+953+947+941+937=9664输入样例2: 12 6输出样例2: 11+7+5+3+2=28---------------------------------------------*/

#include <stdio.h>

int a[11];

int count=0,sum=0;/*count数组中存放素数的个数,sum数组中素数求和*/

void fun(int n,int k)

{

int i,j;

/**********Program**********/

int m;

while(k>0&&n>1)

{ n--;

for(i=2;i<n;i++)

{ if(n%i==0)

{break;}

}

if(i==n)

{ a[count++]=i; k--; }

}

for(m=0;m<k-1;m++)

{ sum=sum+a[m];

printf("%d+",a[i]);

}

printf("%d=%d\n",a[k],sum+a[k]);

/********** End **********/}

int main()

{ int n,k;

printf("\nInput n and k: ");

scanf("%d %d",&n,&k);

fun(n,k);

return 0;}

for(m=0;m<k-1;m++)

改为

for(m=0;m<count-1;m++)

if(i==n)

{ a[count++]=i; k--; }   ---- 你这里k一直在减,最终成为0

}

for(m=0;m<k-1;m++)  ---这里k-1可能是-1,循环根本不执行啊,把k-1改为count吧,你不是用count在计数么

{ sum=sum+a[m];

printf("%d+",a[i]);

}

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632