洛谷 P3383 【模板】线性筛素数
P3383 【模板】线性筛素数
题目描述
如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内)
输入输出格式
输入格式:
第一行包含两个正整数N、M,分别表示查询的范围和查询的个数。
接下来M行每行包含一个不小于1且不大于N的整数,即询问概数是否为质数。
输出格式:
输出包含M行,每行为Yes或No,即依次为每一个询问的结果。
输入输出样例
100 5
2
3
4
91
97
Yes
Yes
No
No
Yes
说明
时空限制:500ms 128M
数据规模:
对于30%的数据:N<=10000,M<=10000
对于100%的数据:N<=10000000,M<=100000
样例说明:
N=100,说明接下来的询问数均不大于100且大于1。
所以2、3、97为质数,4、91非质数。
故依次输出Yes、Yes、No、No、Yes。
/*素数筛 模板*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
int read()
{
int x=,f=;char ch=getchar();
while (ch<'' || ch>'')
{
if(ch=='-')
f=-;
ch=getchar();
}
while (ch>='' && ch<='')
{
x=x*+ch-'';
ch=getchar();
}
return x*f;
}
const int mxn=;
int pri[mxn*],cnt;
bool vis[mxn];
void PRI(int mxn)
{
vis[]=;
int i,j;
for (i=;i<mxn;i++)
{
if (!vis[i])
pri[++cnt]=i;
for (j=;j<=cnt && i*pri[j]<mxn;j++)
{
vis[i*pri[j]]=;
if (i%pri[j]==)
break;
}
}
return;
}
int n,m;
int main()
{
n=read();
m=read();
PRI(n+);
int x;
while (m--)
{
x=read();
if (vis[x])
printf("No\n");
else
printf("Yes\n");
}
return ;
}
洛谷 P3383 【模板】线性筛素数的更多相关文章
- [洛谷P3383][模板]线性筛素数-欧拉筛法
		
Description 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) Input&Output Input 第一行包含两个正整数N.M,分别表示查询的 ...
 - 【埃氏筛】洛谷P3383埃氏筛模板
		
思路: 如果我们要筛出 [1, n] 内的所有素数,使用 [1, √n] 内的素数去筛就可以了 设bool型数组 a,a[i] 表示 i 是否被某个素数筛过 从 2 开始枚举每个数 i: 若 a[i] ...
 - 【洛谷 p3383】模板-线性筛素数(数论)
		
题目:给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内).(N<=10000000,M<=100000) 解法:1.欧拉筛O(n),数组近乎100KB:2.( ...
 - 洛谷P3383 【模板】线性筛素数
		
P3383 [模板]线性筛素数 256通过 579提交 题目提供者HansBug 标签 难度普及- 提交 讨论 题解 最新讨论 Too many or Too few lines 样例解释有问题 ...
 - 洛谷 P3383 【模板】线性筛素数-线性筛素数(欧拉筛素数)O(n)基础题贴个板子备忘
		
P3383 [模板]线性筛素数 题目描述 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) 输入输出格式 输入格式: 第一行包含两个正整数N.M,分别表示查询的范 ...
 - 欧拉函数O(sqrt(n))与欧拉线性筛素数O(n)总结
		
欧拉函数: 对正整数n,欧拉函数是少于或等于n的数中与n互质的数的数目. POJ 2407.Relatives-欧拉函数 代码O(sqrt(n)): ll euler(ll n){ ll ans=n; ...
 - leetcode 204. Count Primes(线性筛素数)
		
Description: Count the number of prime numbers less than a non-negative number, n. 题解:就是线性筛素数的模板题. c ...
 - ACM-ICPC 2018 南京赛区网络预赛 J题Sum(线性筛素数)
		
题目链接:https://nanti.jisuanke.com/t/30999 参考自博客:https://kuangbin.github.io/2018/09/01/2018-ACM-ICPC-Na ...
 - [Luogu]A%BProblem——线性筛素数与前缀和
		
题目描述 题目背景 题目名称是吸引你点进来的[你怎么知道的] 实际上该题还是很水的[有种不祥的预感..] 题目描述 区间质数个数 输入输出格式 输入格式: 一行两个整数 询问次数n,范围m接下来n行, ...
 
随机推荐
- 你好,C++(20).4.2.2  表达并列条件选择的switch语句:如果……如果……如果……
			
4.2.2 表达并列条件选择的switch语句:如果……如果……如果…… 在现实世界中,还有这样一类特殊的条件选择: 如果明天是晴天,我就穿T恤: 如果明天是阴天,我就穿衬衣: 如果明天是雨天,我就 ...
 - Extjs 兼容IE10
			
在对应的地方将Ext.isIE 修改成: Ext.isIE && !(/msie 9/.test(navigator.userAgent.toLowerCase()) &&a ...
 - 3月20日html(二) 图片热点,网页划分,表单
			
1.图片热点: 规划出图片上的一个区域,可以做出超链接,直接点击图片区域就可以完成跳转的效果. <img src=" usemap="map" name=" ...
 - android4.0默认界面旋转180
			
不巧新拿的android4.0默认启动画面和正常显示旋转了180度,即为倒立的.原来是屏输出为倒的,查找得知可以做旋转: 步骤: 一:先把这个加上 然后加上属性ro.sf.hwrotation = 1 ...
 - 测试一下PHP官方的新一代PHP加速插件ZendOpcache的性能及配置
			
过程不表,都比较顺利 参考如下URL: http://www.lvtao.net/server/ZendOpcache.html 大家知道目前PHP的缓存插件一般有三个:APC.eAccelerato ...
 - KEIL简单实例
			
好久都没有用KEIL了,突然想动手,一时还真不知道从哪开始写,所以先弄个小实例,以便参考:#include <reg52.h> //加载包括一个52标准内核的头文件,里面主要是一些寄存器 ...
 - zabbix报警把特定的应用集发送给developer
			
1.创建新的action 2.创建新的develop用户 3.需要删除组不然会给组里所有人发
 - BZOJ1638: [Usaco2007 Mar]Cow Traffic 奶牛交通
			
1638: [Usaco2007 Mar]Cow Traffic 奶牛交通 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 571 Solved: 199 ...
 - Java 内存区域和GC机制-java概念理解
			
推荐几篇关于java内存介绍的文章 Java 内存区域和GC机制 http://www.cnblogs.com/hnrainll/archive/2013/11/06/3410042.html ...
 - 第30讲 UI组件之 GridView组件
			
第30讲 UI组件之 GridView组件 1.网格布局组件GridView GridView是一个ViewGroup(布局控件),可使用表格的方式显示组件,可滚动的控件.一般用于显示多张图片,比如实 ...