http://www.lydsy.com/JudgeOnline/problem.php?id=1951 (题目链接)

题意

  废话一堆。。求解:$$g^{\sum_{d|n} C_n^d}~mod~p$$

Solution

  真的是数论经典题,什么都用上了。

  因为费马小定理,每$p-1$个$g$相乘会得到$1$,那么容易得到:

\begin{aligned} \displaystyle ans &=  g^{\sum_{d|n} C_n^d}~mod~p  \\  &=g^{\sum_{d|n} C_n^d~mod~(p-1)}~mod~p  \end{aligned}

  所以现在关键是求:$$\sum_{d|n} C_n^d~mod~(p-1)$$

  大组合数取模,Lucas定理,可是$p-1$并不是一个质数,怎么办呢。我们考虑用中国剩余定理,先将$p-1$质因数分解,再分别在模各个质因子的的条件下求出余数,最后用中国剩余定理合并得解。

代码

// bzoj1951
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<queue>
#define P 999911659
#define inf 2147483640
#define LL long long
#define free(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout);
using namespace std;int t[4]={2,3,4679,35617};
int n,g,r[4],fac[4][100010];int power(LL a,int b,LL c) {a%=c;LL res=1;while (b) {if (b&1) res=res*a%c;b>>=1;a=a*a%c;}return res;
}
int C(int n,int m,int p) {if (m<n) return 0;return (LL)(fac[p][m]*power((LL)fac[p][n]*fac[p][m-n],t[p]-2,t[p]))%t[p];
}
int Lucas(int n,int m,int p) {if (m==0) return 1;return C(n%t[p],m%t[p],p)*Lucas(n/t[p],m/t[p],p)%t[p];
}
void exgcd(int a,int b,LL &x,LL &y) {if (b==0) {x=1,y=0;return;}exgcd(b,a%b,y,x);y-=a/b*x;
}
int CRT() {LL x,y,M=t[0],R=r[0];for (int i=1;i<4;i++) {int mm=t[i],rr=r[i];exgcd(M,mm,x,y);x=((rr-R)*x%mm+mm)%mm;R+=M*x;M*=mm;}return R;
}
int main() {free("aaa");scanf("%d%d",&n,&g);if (g==P) {printf("0");return 0;}for (int i=0;i<4;i++) {fac[i][0]=1;for (int j=1;j<=t[i];j++)fac[i][j]=fac[i][j-1]*j%t[i];}for (int i=0;i<4;i++)for (int j=1;j*j<=n;j++) if (n%j==0) {r[i]=(r[i]+Lucas(j,n,i))%t[i];if (j*j!=n) r[i]=(r[i]+Lucas(n/j,n,i))%t[i];}printf("%d",power(g,CRT(),P));fclose(stdin);fclose(stdout);return 0;
}

  

转载于:https://www.cnblogs.com/MashiroSky/p/5920406.html

【bzoj1951】 Sdoi2010—古代猪文相关推荐

  1. bzoj1951 [Sdoi2010]古代猪文

    http://www.elijahqi.win/archives/3185 Description "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿 ...

  2. [bzoj1951] [Sdoi2010]古代猪文 费马小定理+Lucas定理+CRT

    Description "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" --选自猪王国民歌 很久 ...

  3. BZOJ1951: [Sdoi2010]古代猪文

    Description "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" --选自猪王国民歌 很久 ...

  4. BZOJ1951 [Sdoi2010]古代猪文 【费马小定理 + Lucas定理 + 中国剩余定理 + 逆元递推 + 扩展欧几里得】...

    题目 "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" --选自猪王国民歌 很久很久以前,在山的那 ...

  5. bzoj千题计划323:bzoj1951: [Sdoi2010]古代猪文(Lucas+CRT+欧拉定理)

    https://www.lydsy.com/JudgeOnline/problem.php?id=1951 先欧拉降幂 然后模数质因数分解 分别计算组合数的结果,中国剩余定理合并 #include&l ...

  6. bzoj1951 [Sdoi2010]古代猪文 lucas+CRT+exgcd

    本来以为要套exlucas的,结果不用,码量就少了很多 注: CRT要  <=0  +=P 区分清楚加减号 码: #include<iostream> #include<cst ...

  7. P2480 [SDOI2010]古代猪文

    P2480 [SDOI2010]古代猪文 题目背景 "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" ...

  8. 1951: [Sdoi2010]古代猪文

    http://www.lydsy.com/JudgeOnline/problem.php?id=1951 题意:求G^(C(N,N/K))%mod ( K|N) 1951: [Sdoi2010]古代猪 ...

  9. BZOJ 1951: [Sdoi2010]古代猪文 [Lucas定理 中国剩余定理]

    1951: [Sdoi2010]古代猪文 Time Limit: 1 Sec  Memory Limit: 64 MB Submit: 2194  Solved: 919 [Submit][Statu ...

  10. P2480 [SDOI2010]古代猪文(数论好题)

    P2480 [SDOI2010]古代猪文 题意: 给你n和g,求g∑d∣nCndmodpg^{\sum_{d|n}C_{n}^{d}}\bmod pg∑d∣n​Cnd​modp p=999911659 ...

最新文章

  1. Cocos 2d-X Lua 游戏添加苹果内购(一) 图文详解准备流程
  2. 通过容器编排和服务网格来改进Java微服务的可测性
  3. 在家学习的核心就是专注
  4. KDE/QT vs GNOME/GTK
  5. Python-函数-Day4
  6. 深入理解WEB请求过程
  7. linux查找时间文件,Linux基础教程 linux下使用find命令根据系统时间查找文件用法(示例代码)...
  8. java解析shell命令_Android中执行java命令的方法及java代码执行并解析shell命令
  9. 源代码src修改为本地图片_20 行 Python 代码批量抓取免费高清图片!
  10. matex2推送鸿蒙系统,拜拜了,Powered by Android!
  11. xp的服务器系统怎么安装win7系统教程,怎么在xp系统下安装win7双系统教程
  12. 力扣题目——235. 二叉搜索树的最近公共祖先
  13. Java的System.out.println并不等于C的printf
  14. 广东再增一项重大跨海工程 黄茅海跨海通道将开建
  15. 条形码生成软件如何批量生成ISBN条码
  16. 自制恋爱话术APP永久免费使用
  17. 阿里云盘小白羊版,带分享功能可转存115文件的第三方客户端
  18. 韶关python培训班_新华字典:韶_“韶”的意思,五笔,笔画,拼音,五行_HttpCN
  19. matlab的tfdata函数_MATLAB 主要函数指令表(按功能分类)
  20. 欧姆龙自动化小型连接器端子台XW2K系列

热门文章

  1. WEB安全,SQL注入漏洞的加固代码汇总
  2. php拍照从手机相册中选择,微信js-sdk预览图片接口及从拍照或手机相册中选图接口用法示例...
  3. 用欧几里得算法求最大公约数_欧几里得算法:GCD(最大公约数),用C ++和Java示例解释...
  4. ios集成firebase_如何将Firebase与您的应用程序集成
  5. 从前端框架到前端架构参考资料
  6. 上课讲到的设计模式总结
  7. Java培训学习步骤有哪些
  8. 第四次作业 (日期和jieba库的运用)
  9. 推荐一款 Flutter Push 推送功能插件
  10. 这是一个不一样的社会公益活动