1013. 数素数 (20)
令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;
}