素数筛总结篇___Eratosthenes筛法和欧拉筛法(*【模板】使用 )
求素数
题目描述
求小于n的所有素数的数量。
输入
多组输入,输入整数n(n<1000000),以0结束。
输出
输出n以内所有素数的个数。
示例输入
10
0
示例输出
4
提示
以这道题目为例,要找出n以内的素数, n<=1000000.
为了节省时间,用素数筛 先把1000000以内的素数全部标记出来!
埃拉托斯特尼筛法,此素数筛核心算法代码:
这样跑完这个代码,是素数的会标记为0, 不是素数的标记为1。 数据处理完毕!
int f[1000004];
int i, j;
memset(f, 0, sizeof(f)); f[1]=1 ; //标记1的不是素数 标记0的是素数
i=2;
while(i<=500000) //这个地方需要优化
{
for(j=i*2; j<=1000000; j+=i )
{
f[j]=1;
}
i++;
while(f[i]==1)
{
i++;
}
}
优化后素数筛模板:10^8的数据,只需要0.34秒筛完
代码【模板使用】:
int f[100000000]; //优化素数筛 筛1百万以内的素数
int main()
{
int i, j;
f[1]=1;
memset(f, 0, sizeof(f));
int dd=sqrt(1e8+0.5);
i=2;
while(i<=dd)
{
for(j=i*2; j<=1000000; j+=i)
f[j]=1; //标记不是素数
i++;
while(f[i]==1)
i++; //移动到下一个是素数的地方
}
//下标从2开始,f[i]=1表示不是素数,f[i]=0是素数
题目代码:
#include <stdio.h>
#include <string.h> int f[1000004]; int main()
{
int n;
int i, j;
memset(f, 0, sizeof(f)); f[1]=1 ; //标记不是
i=2;
while(i<=500000)
{
for(j=i*2; j<=1000000; j+=i )
{
f[j]=1;
}
i++;
while(f[i]==1)
{
i++;
}
} int k, cnt;
while(scanf("%d", &n) && n!=0 )
{
cnt=0;
for(k=1; k<n; k++)
{
if(f[k]==0)
cnt++;
}
printf("%d\n", cnt );
}
return 0;
}
欧拉筛法,程序核心代码:
bool f[N+1]; //标记数组
int num=1; //控制素数表下表
int su[100000]; //素数标
void Oula_shai() //欧拉素数筛法
{
int i, j;
memset(f, true, sizeof(f)); //初始化假设每个数都是素数
for(i=2; i<=N; i++) //从2开始测试
{
if(f[i]==true)
su[num++]=i; //将该数存入素数表
for(j=1; j<num; j++) //遍历整个素数表
{
if(i*su[j]>N) //如果超出了最大上界 跳出
break;
f[i*su[j]]=false; //将倍数从素数筛里筛除
if(i%su[j]==0) //若当前素数是i的最小素因子,则分析下一个整数
break;
}
}
} //注意由于初始化,f[0]和f[1]都是true, 但0和1既不是素数也不是合数
这道题的对应代码:
#include <stdio.h>
#include <string.h>
#include <math.h>
#define N 1000000
bool f[N+1];
int num=1;
int su[100000];
void Oula_shai()
{
int i, j;
memset(f, true, sizeof(f));
for(i=2; i<=N; i++)
{
if(f[i]==true)
su[num++]=i;
for(j=1; j<num; j++)
{
if(i*su[j]>N)
break;
f[i*su[j]]=false;
if(i%su[j]==0)
break;
}
}
} int main()
{
int n;
Oula_shai();
while(scanf("%d", &n)&&n)
{
int ans=0; for(int i=1; i<num; i++)
{
if(su[i]<=n)
ans++;
else
break;
}
printf("%d\n", ans );
}
return 0;
}
素数筛总结篇___Eratosthenes筛法和欧拉筛法(*【模板】使用 )的更多相关文章
- [洛谷P3383][模板]线性筛素数-欧拉筛法
Description 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) Input&Output Input 第一行包含两个正整数N.M,分别表示查询的 ...
- 欧拉筛法模板&&P3383 【模板】线性筛素数
我们先来看欧拉筛法 •为什么叫欧拉筛呢?这可能是跟欧拉有关 •但是为什么叫线性筛呢?因为它的复杂度是线性的,也就是O(n),我们直接来看代码 #include<cstdio> #inc ...
- 『素数 Prime判定和线性欧拉筛法 The sieve of Euler』
素数(Prime)及判定 定义 素数又称质数,一个大于1的自然数,除了1和它自身外,不能整除其他自然数的数叫做质数,否则称为合数. 1既不是素数也不是合数. 判定 如何判定一个数是否是素数呢?显然,我 ...
- 2018牛客网暑期ACM多校训练营(第三场) H - Diff-prime Pairs - [欧拉筛法求素数]
题目链接:https://www.nowcoder.com/acm/contest/141/H 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K ...
- 素数判断-----埃氏筛法&欧拉筛法
埃氏筛法 /* |埃式筛法| |快速筛选素数| |15-7-26| */ #include <iostream> #include <cstdio> using namespa ...
- 【模板】埃拉托色尼筛法 && 欧拉筛法 && 积性函数
埃拉托色尼筛法 朴素算法 1 vis[1]=1; 2 for (int i=2;i<=n;i++) 3 if (!vis[i]) 4 { 5 pri[++tot]=i; 6 for (int j ...
- (数论 欧拉筛法)51NOD 1106 质数检测
给出N个正整数,检测每个数是否为质数.如果是,输出"Yes",否则输出"No". Input 第1行:一个数N,表示正整数的数量.(1 <= N &l ...
- (hdu step 7.2.1)The Euler function(欧拉函数模板题——求phi[a]到phi[b]的和)
题目: The Euler function Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- UVA 10820 欧拉函数模板题
这道题就是一道简单的欧拉函数模板题,需要注意的是,当(1,1)时只有一个,其他的都有一对.应该对欧拉函数做预处理,显然不会超时. #include<iostream> #include&l ...
随机推荐
- C#中用鼠标移动页面功能的实现(代码控制滚动条)
项目中需要实现以下功能: 打印预览控件中,可以用鼠标拖动页面,以查看超出显示范围之外的部分内容. 该功能本来可以通过拉动水平和垂直滚动条来实现,但实际使用中,用户更趋向于直接用鼠标拖动页面来实现,很多 ...
- python之prettytable
sdata={'语文':89,'数学':96,'音乐':39,'英语':78,'化学':88} #字典向Series转化 >>> studata=Series(sdata) > ...
- iOS自己定义对象保存到本地文件
我是将聊天记录存到本地,里边用到了自己定义的对象.把数据转成Data格式存到本地.在转Data格式的时候报错了.这时候须要先将自己定义对象进行归档才干够转Data格式. 方法例如以下: 一.在.h文件 ...
- JQuery的一些思想,自己的一些见解!!!!
自己总结了一下JQuery底层的一些思想,纯属于个人见解.. 为了方便描述,现在客户假如给了我们一个需求: 页面上有两个按钮,一张图片,当我点击hidden按钮时隐藏图片,当我点击show按钮时显示图 ...
- error_logger 爆炸
具有讽刺意味的是,负责错误日志的进程竟然是最为脆弱的之一.在Erlang的缺省安装中,error_logger39负责记录日志(写入磁盘或者发送到网络上),它的速度要比错误产生的速度慢得多.尤其是在记 ...
- Redis单台的安装部署及集群部署
Redis是一种高级key-value数据库.它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富.有字符串,链表,集 合和有序集合.支持在服务器端计算集合的并,交和补集(diff ...
- Docker入门系列3:使用
入门 首先强烈建议玩一遍官方的入门教程,Interactive commandline tutorial,下面是答案: 查看版本:docker version 搜索Image:docker searc ...
- Hive总结(四)hive安装记录
本篇为安装篇较简单: 前提: 1: 安装了hadoop-1.0.4(1.0.3也能够)正常执行 2:安装了hbase-0.94.3, 正常执行 接下来,安装Hive,基于已经安装好的hadoop.过程 ...
- 继承ViewGroup类
Android中,布局都是直接或间接的继承自ViewGroup类,其中,ViewGroup的直接子类目前有: AbsoluteLayout, AdapterView<T extends Adap ...
- IOS简单的渐变绘制
本文转载至 http://www.cnblogs.com/flychen/archive/2012/09/18/2690264.html 前几个星期项目中的音乐列表左边要添加阴影,做成平滑的效果.如图 ...