dididadidi1
2020-06-07 19:55
采纳率: 66.7%
浏览 290

这个程序我写了蛮久但一直得不到答案,也不知道问题出在哪,各位大神可以帮帮我吗?

题目: 编写函数,要求计算并输出不超过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
int a[11];
int count=0,sum=0;/*count数组中存放素数的个数,sum数组中素数求和*/
void fun(int n,int k)
{

int i,j;
/**********Program**********/

for(i=n;i>2;i--){
for(j=2;j<i;j++){
if(i%j==0){
break;}
if(j==i){{
a[count]=i;
count++;
sum+=a[count];}
if(count+1==k)
break;}
}

}
for(count=1;count<k;count++){
printf("%d+",a[count]);}
printf("%d=%d",a[count],sum);

/********** End **********/
}
int main()
{
int n,k;
printf("\nInput n and k: ");scanf("%d %d",&n,&k);
fun(n,k);
return 0;
}

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • hxj19970503 2020-06-07 23:36
    已采纳

    #include
    int a[11] = {0};
    int count=0,sum=0;/*count数组中存放素数的个数,sum数组中素数求和*/
    void fun(int n,int k)
    {

    int i,j;
    /**********Program**********/
    
    for(i=n; i>=2; i--){
        for(j=2; j<i; j++){
            if(i%j == 0){
                break;
            }
        }
        if(j==i){
            a[count]=i;
            sum+=a[count];
            count++;
        }
        if(count == k)
            break;
    }
    
    for(count = 0; count < k; count++){
        if (a[count] == 0)
            break;
        printf("%d+",a[count]);
    }
    printf("\b");
    printf("=%d", sum);
    // printf("%d=%d",a[count],sum);
    
    /********** End **********/
    

    }

    int main()
    {
    int n,k;
    printf("\nInput n and k: ");
    scanf("%d %d",&n,&k);
    fun(n,k);
    return 0;
    }

    已采纳该答案
    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题