0
点赞
收藏
分享

微信扫一扫

1013. 数素数 (20)


1013. 数素数 (20)


时间限制



100 ms



内存限制



65536 kB



代码长度限制



8000 B



判题程序



Standard



作者



CHEN, Yue


令Pi表示第i个素数。现任给两个正整数M <= N <= 104,请输出PM到PN的所有素数。

输入格式:

输入在一行中给出M和N,其间以空格分隔。

输出格式:

输出从PM到PN的所有素数,每10个数字占1行,其间以空格分隔,但行末不得有多余空格。


输入样例:


5 27


输出样例:


11 13 17 19 23 29 31 37 41 43 47 53 59 61 67 71 73 79 83 89 97 101 103


筛法求素数:
#include<stdio.h>
 void isprime();
    int i,k=0,j;
bool p[105000]={0};
int a[11000];




 int main()
 {
int m,n,count=0,num=0;
scanf("%d %d",&m,&n); 
isprime();
     for(k=m-1;k<n;k++)
{
       count++;
num++;
if(count==1||(num-1)%10==0)printf("%d",a[k]);
else
printf(" %d",a[k]);
if(num%10==0)
{
printf("\n");
}
} 
 }


 void isprime()
 {
//int i,k=0,j;
 // bool p[100000]={0};
 // int a[10010];
for(i=2;i<104730;i++)
{
if(p[i]==false)  a[k++]=i;
for(j=i+i;j<104730;j+=i)
{
p[j]=true;
}
}
 }





方法二:
 #include<stdio.h>

 #include<math.h>

 bool isprime(int a);

 int main()

 {

int m,n,j,num=0,prime[10010],k=0,count=0;

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

for(j=2;j<=104732;j++)

{

if(isprime(j)==true)

{

prime[k++]=j;

}

}

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

{

    
   count++;

num++;

if(count==1||(num-1)%10==0)printf("%d",prime[k]);

else

printf(" %d",prime[k]);

if(num%10==0)

{

printf("\n");

}

} 

 }

 //用原方法当对时间复杂度卡的很严格的时候明显 不可以,得使用筛选法 

 bool isprime(int a)

 {

    int  i,b;

    b=(int)sqrt(a);

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

    {

    
   if(a%i==0)

    
   {

           return false; 

  }

    }

    
  return true;

 }

举报

相关推荐

0 条评论