freemandj 2019-12-01 12:51 采纳率: 100%
浏览 714
已采纳

我写了一个,但答案不对(每行不到十个就换行了),希望帮忙改一下,谢谢

7-10 输出2到n之间的全部素数 (20 分)
本题要求输出2到n之间的全部素数,每行输出10个。素数就是只能被1和自身整除的正整数。注意:1不是素数,2是素数。

输入格式:
输入在一行中给出一个长整型范围内的整数。

输出格式:
输出素数,每个数占6位,每行输出10个。如果最后一行输出的素数个数不到10个,也需要换行。

输入样例:
10
输出样例:
2 3 5 7

这是我写的

    #include<stdio.h>

#include
long int sushu(long int n);
int main()
{
long int i,number,count=0;
scanf("%d",&number);
for(i=2;i<=number;i++)
{
if(sushu(i)==1)
printf("%6d",i);
count++;
if(count%10==0){
printf("\n");}
}
if(count%10!=0)
printf("\n");
}
long int sushu(long int n)
{
int i;
float pf;
pf=sqrt(n);
for(i=2;i<=pf;i++)
{
if(n%i==0||n==1)
return 0;

}
if(i>pf)
return 1;
}

  • 写回答

1条回答 默认 最新

  • threenewbee 2019-12-01 12:56
    关注
    #include<stdio.h>
    #include<math.h>
    long int sushu(long int n);
    int main()
    {
    long int i,number,count=0;
    scanf("%d",&number);
    for(i=2;i<=number;i++)
    {
    if(sushu(i)==1){
    printf("%6d",i);
    count++;
    if(count%10==0)
    printf("\n");
    }
    }
    }
    long int sushu(long int n)
    {
    int i;
    float pf;
    pf=sqrt((double)n);
    for(i=2;i<=pf;i++)
    {
    if(n%i==0||n==1)
    return 0;
    
    }
    if(i>pf)
    return 1;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料