我们一般写的埃氏筛消耗的时间都是欧拉筛的三倍,但是欧拉筛并不好想(对于我这种蒟蒻)

虽然 -- 我 -- 也可以背过模板,但是写个不会的欧拉筛不如写个简单易懂的埃氏筛

于是就有了优化

这个优化还是比较厉害的,能把埃氏筛的消耗的时间提的跟欧拉筛差不多


以下内容需要先学会埃氏筛

学会的埃氏筛就明白它的原理了吧

#include<bits/stdc++.h>
using namespace std;
int n, m ,Is_p[10000001];
int main() {
cin >> n >> m;
Is_p[1] = 1;
for(int i = 2; i <= n; ++i)
if(Is_p[i] == 0)
for(int j = 2; i * j <= n; ++j)
Is_p[i * j] = 1;
int a = 0;
for(int i = 1; i <= m ;++i) {
scanf("%d", &a);
if(Is_p[a] == 1) cout << "No\n";
else cout << "Yes\n";
}
return 0;
}

这是一种最普通的埃氏筛了

由于我的小号名字很嚣张,我就抹掉了

运行总时间是4000多ms

炒鸡慢啊,有木有

在这份代码中有一个地方明显可以优化

     for(int i = 2; i <= n; ++i)
if(Is_p[i] == 0)
// for(int j = 2; i * j <= n; ++j)
Is_p[i * j] = 1;
1.

绿油油的那行就是,i * j <= n,这个语句中每次执行循环都会执行一遍

i * j执行多了也会卡的,所以不如定义一个数(yy) = n / i , j只需要枚举到yy就可以.

2.

还有最外层循环的i <= n,其实没必要执行这么多次,因为一个数n总能被

√n 筛掉所以只需要枚举到√n.

但是sqrt(n)算多了反而得不偿失,所以像刚才一样处理

3.

还有一个更重要的地方,也是每一个课本上都讲过的,j只需要从i开始,为什么课本上都有.

完成这3项,埃氏筛也基本不能更快了,

交上去试试:

我同学的欧拉筛(这是位dalao,没事可以加他去膜一膜,他有多么强呢?他跟我学的时间差不多,我才刚学树,他就已经会了主席树......)

可以看到10个点总共慢了200ms,平均一个才慢20ms.

估计没有出题人可以把时间卡的这么"好"(让欧拉筛过,但不让埃氏筛过)吧

而且我占的空间比他少的多

我来顺便分析一下他的名字,其实他的名字后两个字是带三点水的但是去掉了,并且在前面加上了个水比

这说明了什么,他想说明他"没有水",但是说自己很水,

用人话来讲就是:不水而且很谦虚

上述内容纯属扯淡,进入正题

emmmm..好像没什么要说的了

交代

                   .-' _..`.
/ .'_.'.'
| .' (.)`.
;' ,_ `.
.--.__________.' ; `.;-'
| ./ /
| | /
`..'`-._ _____, ..'
/ | | | |\ \
/ /| | | | \ \
/ / | | | | \ \
/_/ |_| |_| \_\
|__\ |__\ |__\ |__\

#include<bits/stdc++.h>
using namespace std;
bool a[10000001];
void ol(int x){
int xx = sqrt(x);
for (int i = 2; i <= xx; ++i)
{
if (a[i] == 0)
{
int yy = x / i;
for (int j = i; j <= yy; ++j)
{
a[i * j] = 1;
}
}
}
} int main()
{
int n,m,t;
cin>>n>>m;
a[0] = 1;//这里要特判一下,不然会WA两个点
a[1] = 1;
ol(n);
for(int i=1;i<=m;i++){
scanf("%d",&t);
if(a[t] == 0)
cout<<"Yes"<<endl;
else
cout<<"No"<<endl;
}
return 0;
}

我把欧拉筛也贴上吧

#include<cstdio>
#include<iostream>
using namespace std;
int n, m, p[10000001], cnt, IsNotPrime[10000001];
int main() {
scanf("%d%d", &n, &m);
IsNotPrime[0] = IsNotPrime[1] = 1;
for(int i=2; i < n; ++i) {
if(!IsNotPrime[i]) p[++cnt] = i;
for(int j = 1; i*p[j] <= n && j <= cnt; ++j) {
IsNotPrime[i * p[j]] = 1;
if(! (i % p[j])) break;
}
}
int k;
for(int i = 1; i <= m; ++i) {
scanf("%d", &k);
if(IsNotPrime[k]) cout << "No\n";
else cout << "Yes\n";
}
return 0;
}

埃氏筛优化(速度堪比欧拉筛) + 洛谷 P3383 线性筛素数 题解的更多相关文章

  1. 洛谷P3383线性筛素数

    传送门 代码中体现在那个 $ break $ $ prime $ 数组 中的素数是递增的,当 $ i $ 能整除 $ prime[j ] $ ,那么 $ iprime[j+1] $ 这个合数肯定被 $ ...

  2. 欧拉筛(线性筛) & 洛谷 P3383 【模板】线性筛素数

    嗯.... 埃氏筛和欧拉筛的思想都是相似的: 如果一个数是素数,那么它的所有倍数都不是素数.... 这里主要介绍一下欧拉筛的思路:(欧拉筛的复杂度大约在O(n)左右... 定义一个prime数组,这个 ...

  3. 【BZOJ4805】欧拉函数求和(杜教筛)

    [BZOJ4805]欧拉函数求和(杜教筛) 题面 BZOJ 题解 好久没写过了 正好看见了顺手切一下 令\[S(n)=\sum_{i=1}^n\varphi(i)\] 设存在的某个积性函数\(g(x) ...

  4. 【埃氏筛】洛谷P3383埃氏筛模板

    思路: 如果我们要筛出 [1, n] 内的所有素数,使用 [1, √n] 内的素数去筛就可以了 设bool型数组 a,a[i] 表示 i 是否被某个素数筛过 从 2 开始枚举每个数 i: 若 a[i] ...

  5. 欧拉筛法模板and 洛谷 P3383 【模板】线性筛素数(包括清北的一些方法)

    题目描述 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) 输入格式 第一行包含两个正整数N.M,分别表示查询的范围和查询的个数. 接下来M行每行包含一个不小于1 ...

  6. [洛谷P3383][模板]线性筛素数-欧拉筛法

    Description 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) Input&Output Input 第一行包含两个正整数N.M,分别表示查询的 ...

  7. 洛谷 P3383 【模板】线性筛素数-线性筛素数(欧拉筛素数)O(n)基础题贴个板子备忘

    P3383 [模板]线性筛素数 题目描述 如题,给定一个范围N,你需要处理M个某数字是否为质数的询问(每个数字均在范围1-N内) 输入输出格式 输入格式: 第一行包含两个正整数N.M,分别表示查询的范 ...

  8. bzoj 4916: 神犇和蒟蒻【欧拉函数+莫比乌斯函数+杜教筛】

    居然扒到了学长出的题 和3944差不多(?),虽然一眼看上去很可怕但是仔细观察发现,对于mu来讲,答案永远是1(对于带平方的,mu值为0,1除外),然后根据欧拉筛的原理,\( \sum_{i=1}^{ ...

  9. 51nod 1237 最大公约数之和 V3【欧拉函数||莫比乌斯反演+杜教筛】

    用mu写lcm那道卡常卡成狗(然而最后也没卡过去,于是写一下gcd冷静一下 首先推一下式子 \[ \sum_{i=1}^{n}\sum_{j=1}^{n}gcd(i,j) \] \[ \sum_{i= ...

随机推荐

  1. 用友U9 部署

    手工部署 对于插件式开发,或者自定义单据开发,无法用U9构造系统生成补丁包,所以必须手工部署. 部署文件 脚本:直接执行(最好有事务保护) Deploy文件:拷贝到Potal\ApplicationL ...

  2. 聊聊Golang逃逸分析

    逃逸分析的概念,go怎么开启逃逸分析的log. 以下资料来自互联网,有错误之处,请一定告之. 什么是逃逸分析 wiki上的定义 在编译程序优化理论中,逃逸分析是一种确定指针动态范围的方法——分析在程序 ...

  3. Restart container within pod

    https://stackoverflow.com/questions/46123457/restart-container-within-pod 命令 kubectl exec -it [POD_N ...

  4. python基础08--迭代器,生成器

    1.1 迭代器 1.可迭代对象:str,list,tuple,set,dict, 迭代器:f(文件),range() 可迭代对象和迭代器都可以for循环 可迭代对象不会计数, 迭代器会计数,上面操作到 ...

  5. ssh工具推荐

    FinalShell 看图就知道功能多强大了, 官网地址 http://www.hostbuf.com

  6. echarts的地图省份颜色自适应变化

    在使用echarts的地图的时候省份的颜色可能随着数据的多少显示不同的颜色,但是当后台返回的数据的变化较大时可能就不好控制了,所以需要设置根据后台的数据进行自适应 将后台返回的数据中的value放入一 ...

  7. QT制作一个位图画图板程序

    本文学习如何创建一个Qt绘制程序,用户将能够通过使用不同的尺寸和画笔的颜色来表达他们的创造力. 主要功能:保存画板内容为图片.清除画板内容.设置画板大小.设置画笔颜色 新建基于QMainWindow的 ...

  8. Unity编辑器扩展中,使用Unity自带的GUIStyle

    在进行编辑器扩展时,创建组件的方法一般都会提供GUIStyle参数,可以让我们自定义样式.修改背景图,字体大小,颜色等等. 比如,创建Button组件的方法:public static bool Bu ...

  9. RxJS——调度器(Scheduler)

    调度器 什么是调度器?调度器是当开始订阅时,控制通知推送的.它由三个部分组成. 调度是数据结构.它知道怎样在优先级或其他标准去存储和排队运行的任务 调度器是一个执行上下文.它表示任务在何时何地执行(例 ...

  10. java比较两个小数的大小

    BigDecimal data1 = new BigDecimal("1");BigDecimal data2 = new BigDecimal("1.0"); ...