LOJ6235 区间素数个数(min_25筛)
题目链接:LOJ
题目大意:看到题目名字应该都知道是啥了吧。
$1\le N\le 10^{11}$。
阉割版 min_25 筛。发现答案实际上就是 min_25 筛中 $g(N,pl)$ 的值。(取次数 $k=0$ 即可)
在这里再写一遍式子。(用久了应该要背了)
$g(n,0)=n-1$
$g(n,j)=\begin{cases}g(n,j-1)&p_j^2>n\\g(n,j-1)-(g(\lfloor\dfrac{n}{p_j}\rfloor,j)-(j-1))&p_j^2\le n\end{cases}$
直接算即可。时间复杂度 $O(\frac{N^{3/4}}{\log N})$。
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=;
#define FOR(i,a,b) for(int i=(a);i<=(b);i++)
#define ROF(i,a,b) for(int i=(a);i>=(b);i--)
#define MEM(x,v) memset(x,v,sizeof(x))
ll n,w[maxn],g[maxn];
int sq,pri[maxn],pl,tot,id1[maxn],id2[maxn];
bool vis[maxn];
inline int id(ll x){return x<=sq?id1[x]:id2[n/x];}
void init(){
sq=sqrt(n);
FOR(i,,sq){
if(!vis[i]) pri[++pl]=i;
FOR(j,,pl){
if(i*pri[j]>sq) break;
vis[i*pri[j]]=true;
if(i%pri[j]==) break;
}
}
for(ll l=,r;l<=n;l=r+){
r=n/(n/l);
w[++tot]=n/l;
if(n/l<=sq) id1[n/l]=tot;
else id2[n/(n/l)]=tot;
g[tot]=w[tot]-;
}
}
void calc(){
FOR(i,,pl) FOR(j,,tot){
if((ll)pri[i]*pri[i]>w[j]) break;
g[j]-=g[id(w[j]/pri[i])]-(i-);
}
}
int main(){
scanf("%lld",&n);
init();
calc();
printf("%lld\n",g[id(n)]);
}
LOJ6235 区间素数个数(min_25筛)的更多相关文章
- LOJ.6235.区间素数个数(Min_25筛)
		
题目链接 \(Description\) 给定\(n\),求\(1\sim n\)中的素数个数. \(2\leq n\leq10^{11}\). \(Solution\) Min_25筛.只需要求出\ ...
 - [LOJ6235]区间素数个数
		
题目大意: 给定$n(n\leq10^{11})$,求$\pi(n)$. 思路: 计算$\pi$函数有$O(n^{\frac23})$的Lehmer算法,这里考虑$O(\frac{n^{\frac34 ...
 - loj#6235. 区间素数个数(min25筛)
		
题意 题目链接 Sol min25筛的板子题,直接筛出\(g(N, \infty)\)即可 筛的时候有很多trick,比如只存\(\frac{N}{x}\)的值,第二维可以滚动数组滚动掉 #inclu ...
 - loj #6235. 区间素数个数
		
#6235. 区间素数个数 题目描述 求 1∼n 1\sim n1∼n 之间素数个数. 输入格式 一行一个数 n nn . 输出格式 一行一个数,表示答案. 样例 样例输入 10 样例输出 4 样例解 ...
 - loj #6235. 区间素数个数 min_12.5筛
		
\(\color{#0066ff}{ 题目描述 }\) 求 \(1\sim n\) 之间素数个数. \(\color{#0066ff}{输入格式}\) 一行一个数 n . \(\color{#0066 ...
 - LightOj 1197 - Help Hanzo(分段筛选法 求区间素数个数)
		
题目链接:http://lightoj.com/volume_showproblem.php?problem=1197 题意:给你两个数 a b,求区间 [a, b]内素数的个数, a and b ( ...
 - Prime Count  求大区间素数个数
		
http://acm.gdufe.edu.cn/Problem/read/id/1333 https://www.zhihu.com/question/29580448/answer/44874605
 - Min_25筛 学习笔记
		
这儿只是一个简单说明/概括/总结. 原理见这: https://www.cnblogs.com/cjyyb/p/9185093.html https://www.cnblogs.com/zhoushu ...
 - 模板 - 数学 - 数论 - Min_25筛
		
终于知道发明者的正确的名字了,是Min_25,这个筛法速度为亚线性的\(O(\frac{n^{\frac{3}{4}}}{\log x})\),用于求解具有下面性质的积性函数的前缀和: 在 \(p\) ...
 
随机推荐
- Javascript函数的参数arguments
			
arguments Description 在所有的函数中有一个arguments对象,arguments对象指向函数的参数,arguments object is an Array-like obj ...
 - 数据库+maven
			
1.mysql <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-ja ...
 - PyQt5布局管理(1)
			
Qt布局管理按简单分可分为绝对位置布局和布局管理器布局 一.绝对位置布局: 组件不放在布局管理器中,通过函数setGeometry(x,y,width,height)来设定组件相对其父窗口的位置.其中 ...
 - python中的生成器(generator)总结
			
1.实现generator的两种方式 python中的generator保存的是算法,真正需要计算出值的时候才会去往下计算出值.它是一种惰性计算(lazy evaluation). 要创建一个gene ...
 - tensorflow中常量(constant)、变量(Variable)、占位符(placeholder)和张量类型转换reshape()
			
常量 constant tf.constant()函数定义: def constant(value, dtype=None, shape=None, name="Const", v ...
 - node.js 安装及配置(hello world)及 node 的包管理器(npm)
			
下载地址:Download | Node.js,无脑下一步安装即可: 安装时,会自动将 node 可执行文件路径添加进 Path 内,这样进入 cmd 命令行,以查看 node 的安装版本: > ...
 - 1068 Find More Coins (30)(30 分)
			
Eva loves to collect coins from all over the universe, including some other planets like Mars. One d ...
 - ACM学习历程—HDU4746 Mophues(莫比乌斯)
			
Description As we know, any positive integer C ( C >= 2 ) can be written as the multiply of some ...
 - bzoj 2594: 水管局长数据加强版 Link-Cut-Tree
			
题目: Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公 ...
 - 【LeetCode】024. Swap Nodes in Pairs
			
Given a linked list, swap every two adjacent nodes and return its head. For example,Given 1->2-&g ...