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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[欧拉函数] Bzoj P2186 沙拉公主的困惑

發(fā)布時(shí)間:2023/12/2 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [欧拉函数] Bzoj P2186 沙拉公主的困惑 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Description

  大富翁國因?yàn)橥ㄘ浥蛎?#xff0c;以及假鈔泛濫,政府決定推出一項(xiàng)新的政策:現(xiàn)有鈔票編號(hào)范圍為1到N的階乘,但是,政府只發(fā)行編號(hào)與M!互質(zhì)的鈔票。房地產(chǎn)第一大戶沙拉公主決定預(yù)測(cè)一下大富翁國現(xiàn)在所有真鈔票的數(shù)量?,F(xiàn)在,請(qǐng)你幫助沙拉公主解決這個(gè)問題,由于可能張數(shù)非常大,你只需計(jì)算出對(duì)R取模后的答案即可。R是一個(gè)質(zhì)數(shù)。

?

題解

  • gcd(i,m!)=1所以gcd(i+m!,m!)=1
  • 所以每m!個(gè)所含的與m!互質(zhì)的數(shù)的個(gè)數(shù)是一樣的
  • 所以φ(m!)*n!/m!
  • 然后就線性篩就好了

?

代碼

1 #include <cstdio> 2 #include <iostream> 3 #define N 10000010 4 #define ll long long 5 using namespace std; 6 int T,mo,n,m,ans[N],fac[N],inv[N],p[N],bz[N]; 7 int main() 8 { 9 scanf("%d%d",&T,&mo),fac[1]=inv[1]=ans[1]=1; 10 for (int i=2;i<=N;i++) fac[i]=(ll)fac[i-1]*i%mo,inv[i]=(mo-(ll)mo/i*inv[mo%i]%mo); 11 for (int i=2;i<=N;i++) 12 { 13 if (!bz[i]) p[++p[0]]=i; 14 for (int j=1;p[j]*i<=N&&j<=p[0];j++) 15 { 16 bz[p[j]*i]=1; 17 if (i%p[j]==0) break; 18 } 19 } 20 for (int i=2;i<=N;i++) 21 { 22 ans[i]=ans[i-1]; 23 if (!bz[i]) ans[i]=(ll)ans[i]*(i-1)%mo*inv[i%mo]%mo; 24 } 25 while (T--) scanf("%d%d",&n,&m),printf("%d\n",(ll)fac[n]*ans[m]%mo); 26 }

?

轉(zhuǎn)載于:https://www.cnblogs.com/Comfortable/p/11319878.html

總結(jié)

以上是生活随笔為你收集整理的[欧拉函数] Bzoj P2186 沙拉公主的困惑的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。