BZOJ 1951 【SDOI2010】 古代猪文
题目链接:古代猪文
好久没写博客了,这次就先写一篇吧……
题面好鬼……概括起来就是:给出\(N,G(\leqslant 10^9)\),求:\[G^{\sum_{d|n}\binom{n}{d}} \bmod p \]
其中\(p=999911659\),是一个质数。
首先,当\(G\neq p\)时,由欧拉定理可知\[G^x\equiv G^{x\bmod(p-1)}(\bmod p)\]
然后我们实际上就是要快速计算\[\sum_{d|n}\binom{n}{d} \bmod(p-1)\]
由于\(p-1\)不是一个质数,我们可以把它给质因数分解了,得到\(p-1=2\times 3\times 4679\times 35617\)
然后分别在模这些数的情况下用\(Lucas\)定理算出组合数,再中国剩余定理合并。用中国剩余定理的时候注意有多个模数,不要弄混了。
复习一下\(Lucas\)定理,当\(p\)为质数时,有:\[\binom{a}{b} \equiv \binom{\lfloor \frac{a}{p} \rfloor}{\lfloor \frac{b}{p} \rfloor} \binom{a\bmod p}{b\bmod p}(\bmod p)\]
中国剩余定理复习:xlightgod的博客、Mashirosky的博客
下面贴代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define mod 999911659
#define maxn 40010 using namespace std;
typedef long long llg; int n,g,pr,pk,pri[4]={2,3,4679,35617};
llg jie[4][maxn],ni[4][maxn],zhi; llg mi(llg a,int b){
llg s=1;
while(b){
if(b&1) s=s*a%pr;
a=a*a%pr; b>>=1;
}
return s;
} llg C(int x,int y){return x<y?0:jie[pk][x]*ni[pk][y]%pr*ni[pk][x-y]%pr;}
llg lucas(int x,int y){
if(!y) return 1; if(x<y) return 0;
return lucas(x/pr,y/pr)*C(x%pr,y%pr)%pr;
} llg hebing(int x,int y){
llg now=0;
for(int k=0;k<4;k++){
pr=pri[k],pk=k;
now+=(mod-1)/pr*mi((mod-1)/pr,pr-2)*lucas(x,y);
now%=mod-1;
}
return now;
} int main(){
File("a");
scanf("%d %d",&n,&g);
if(mod==g){putchar('0');return 0;}
for(int k=0;k<4;k++){
jie[k][0]=1; pr=pri[k]; pk=k;
for(int i=1;i<pr;i++) jie[k][i]=jie[k][i-1]*i%pr;
ni[k][pr-1]=mi(jie[k][pr-1],pr-2);
for(int i=pr-1;i;i--) ni[k][i-1]=ni[k][i]*i%pr;
}
for(int d=1,l=sqrt(n);d<=l;d++)
if(n%d==0){
zhi+=hebing(n,d);
if(n/d!=d) zhi+=hebing(n,n/d);
zhi%=(mod-1);
}
pr=mod; printf("%lld",mi(g,zhi));
return 0;
}
BZOJ 1951 【SDOI2010】 古代猪文的更多相关文章
- BZOJ 1951: [Sdoi2010]古代猪文( 数论 )
显然答案是G^∑C(d,N)(d|N).O(N^0.5)枚举N的约数.取模的数999911659是质数, 考虑欧拉定理a^phi(p)=1(mod p)(a与p互质), 那么a^t mod p = a ...
- BZOJ 1951: [Sdoi2010]古代猪文 [Lucas定理 中国剩余定理]
1951: [Sdoi2010]古代猪文 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 2194 Solved: 919[Submit][Status] ...
- 【刷题】BZOJ 1951 [Sdoi2010]古代猪文
Description "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" --选自猪王国民歌 很久 ...
- bzoj 1951 [Sdoi2010]古代猪文(数论知识)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1951 [思路] 一道优(e)秀(xin)的数论题. 首先我们要求的是(G^sigma{ ...
- bzoj 1951 [Sdoi2010]古代猪文 ——数学综合
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1951 数学综合题. 费马小定理得指数可以%999911658,又发现这个数可以质因数分解.所 ...
- bzoj 1951: [Sdoi2010]古代猪文
#include<cstdio> #include<iostream> #include<cstring> #include<cmath> #defin ...
- BZOJ.1951.[SDOI2010]古代猪文(费马小定理 Lucas CRT)
题目链接 \(Description\) 给定N,G,求\[G^{\sum_{k|N}C_n^k}\mod\ 999911659\] \(Solution\) 由费马小定理,可以先对次数化简,即求\( ...
- bzoj 1951: [Sdoi2010]古代猪文 【中国剩余定理+欧拉定理+组合数学+卢卡斯定理】
首先化简,题目要求的是 \[ G^{\sum_{i|n}C_{n}^{i}}\%p \] 对于乘方形式快速幂就行了,因为p是质数,所以可以用欧拉定理 \[ G^{\sum_{i|n}C_{n}^{i} ...
- BZOJ 1951 [SDOI2010]古代猪文 (组合数学+欧拉降幂+中国剩余定理)
题目大意:求$G^{\sum_{m|n} C_{n}^{m}}\;mod\;999911659\;$的值$(n,g<=10^{9})$ 并没有想到欧拉定理.. 999911659是一个质数,所以 ...
- BZOJ 1951: [Sdoi2010]古代猪文 ExCRT+欧拉定理+Lucas
欧拉定理不要忘记!! #include <bits/stdc++.h> #define N 100000 #define ll long long #define ull unsigned ...
随机推荐
- highmaps如何自定义 区间的颜色刻度
https://api.highcharts.com/highmaps/colorAxis.dataClassColor http://jsfiddle.net/gh/get/library/pure ...
- Xcode - 插件管理工具Alcatraz
Alcatraz 1.简介 Alcatraz是一个能帮你管理Xcode插件丶模版及颜色配置的工具.它可以直接集成在Xcode的图形界面中,让你感觉就像在使用Xcode自带的功能一样. 2.安装和删除 ...
- postgresql----TEMPORARY TABLE和UNLOGGED TABLE
一.TEMPORARY|TEMP TABLE 会话级或事务级的临时表,临时表在会话结束或事物结束自动删除,任何在临时表上创建的索引也会被自动删除.除非用模式修饰的名字引用,否则现有的同名永久表在临时表 ...
- 170602、防止sql注入(一)
一.SQL注入简介 SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编程时的疏忽,通过SQL语句,实现无帐号登录,甚至篡改数据库. 二.SQL注入攻击的总体 ...
- Zabbix邮件告警提示Couldn't resolve host name解决办法
zabbix设置好邮件告警,当有触发时邮件未发送 查看zabbix server日志,提示不能连接邮件发送服务器,但是ping是可以通的
- A Benchmark Comparsion of Monocular Visual-Inertial Odometry Algorithms for Flying Robots论文笔记
摘要: 本文主要比较单目VIO的算法在飞行机器人上运行的性能,测试使用统一数据集为EuRoC.其中评价指标为:姿态估计精度.每帧处理时间以及CPU和内存负载使用率,同时还有RMSE(运行轨迹与真实轨迹 ...
- nginx简介和配置gd
转自:https://www.cnblogs.com/zhouxinfei/p/7862285.html nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也 ...
- 解决SpringMVC中文乱码
第一种:表单提交后controller获得中文参数后乱码解决方案 注意: 1: form表单提交方式为必须为post,get方式下面spring编码过滤器不起效果 2: jsp页面编码设置为UTF-8 ...
- Python性能分析指南(未完成)
英文原文:http://www.huyng.com/posts/python-performance-analysis/ 译文:http://www.oschina.net/translate/pyt ...
- Myeclipse文档注释如何提炼(导出)成自己的API帮助文档?
第一步: 源码注释规范,一定要用/** 两个*这一特殊的注释.注释上可以添加@author等特殊说明,下图是部分 javadoc 标记 信息,可以根据需要选用. 第二步: 确保整个工程的项目都添加 ...