P2350-[HAOI2012]外星人【线性筛】
正題
題目鏈接:https://www.luogu.com.cn/problem/P2350
題目大意
給出NNN質因數分解之后的結果,求每次N=φ(N)N=\varphi(N)N=φ(N),多少次后N=1N=1N=1。
N=∏i=1mpiqi,1≤m≤2000,1≤pi≤105,1≤qi≤109N=\prod_{i=1}^mp_i^{q_i},1\leq m\leq 2000,1\leq p_i\leq 10^5,1\leq q_i\leq 10^9N=∏i=1m?piqi??,1≤m≤2000,1≤pi?≤105,1≤qi?≤109
解題思路
我是傻逼((((
首先φ(∏i=1mpiqi)=∏i=1m(pi?1)piqi?1\varphi(\prod_{i=1}^mp_i^{q_i})=\prod_{i=1}^m(p_i-1)p_i^{q_i-1}φ(∏i=1m?piqi??)=∏i=1m?(pi??1)piqi??1?
開始想太多了,以為傳遞的延遲影響很大,后來發現設因為pi?1p_i-1pi??1一定是偶數,所以把pi?1p_i-1pi??1分解后一定有222這個質因子,所以只有在NNN沒有222這個質因子的情況下傳遞的延遲會造成一次的影響,否則都沒有影響,因為222還沒有抵消延遲就已經結束了。
所以我們只需要考慮每個質數能傳遞出多少個222,這個用線性篩可以解決因為最后更新一個質數的一定是新增的一個質因子。
code
#include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int N=1e5+10,M=1e5+10; int T,n,cnt,pri[N],f[M],v[M]; void Prime(){f[1]=1;for(int i=2;i<M;i++){if(!v[i])pri[++cnt]=i,f[i]=f[i-1];for(int j=1;j<=cnt&&i*pri[j]<M;j++){v[i*pri[j]]=1;f[i*pri[j]]=f[i]+f[pri[j]];if(i%pri[j]==0)break;}}return; } int main() {Prime();scanf("%d",&T);while(T--){scanf("%d",&n);if(!n)puts("0");long long ans=1;for(int i=1;i<=n;i++){int x,w;scanf("%d%d",&x,&w);if(x==2)ans--;ans+=1ll*f[x]*w;}printf("%lld\n",ans);}return 0; }總結
以上是生活随笔為你收集整理的P2350-[HAOI2012]外星人【线性筛】的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: P6775-[NOI2020]制作菜品【
- 下一篇: 联通路由器信道怎么设置路由器的信道怎么改