1013. 数素数 (20)

来源:互联网 发布:拿破仑为什么伟大 知乎 编辑:程序博客网 时间:2024/04/29 21:49

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 4347 53 59 61 67 71 73 79 83 8997 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 0