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
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- 1013. 数素数 (20)
- Java的登记式单例代码
- C++转向C#的疑惑:难道C#中没有拷贝构造函数 ?
- Media Query媒体查询
- 十进制小数<==>二进制小数
- HDU 1035
- 1013. 数素数 (20)
- 蓝桥杯 入门训练 序列求和
- Head First C (前半部分)读书笔记
- 百度开放平台SDK错误解决
- SqliteDatabase insert(String table, String nullColumnHack, ContentValues values)
- arduino按钮控制LED
- C++蓝桥杯基础练习 特殊回文数
- Ios 2015 年最热门的 10 篇技术文章
- [GDKOI模拟2016.01.24总结]