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;
 }









