日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

P2350-[HAOI2012]外星人【线性筛】

發布時間:2023/12/3 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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??,1m2000,1pi?105,1qi?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]外星人【线性筛】的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。