[SDOI2010]古代猪文 (欧拉,卢卡斯,中国剩余)
[SDOI2010]古代猪文
$ solution: $
这道题感觉综合性极强,用到了许多数论中的知识:
- 质因子,约数,组合数
- 欧拉定理
- 卢卡斯定理
- 中国剩余定理
首先我们读题,发现题目需要我们枚举k(就是n的所有约数),并且对于每一个k都要用一个组合数算出其情况数(读题:不过具体是哪k分之一。这句话说明我们可以从n中取出任意k个字,所以情况数就是 $ C(_n^k) $ )(然后因为我们求的组合数范围有点大,所以需要用卢卡斯定理来求组合数(接下来我们会发现模数其实比较小))。但是这道题目把所有情况数(设有tot个情况),求为 $ G^{tot} $ 作答案输出。
众所周知,指数是不能直接取模的,所以我们要用到欧拉定理(注意欧拉定理建立在 $ gcd(G,999911659)=1 $ 的情况下,所以读入时要特判!)。
$ G{tot}=G{(tot\ mod \ \phi(P)+\phi(P))}\ mod(P) $
因为我们的模数为999911659(质数),所以我们其实就是要求这个东西:
$ G^{(tot\ mod \ 999911658+999911658)} $
但是我们发现虽然我们现在可以取模了,但是999911658并不是一个质数,而我们求tot的时候是需要用卢卡斯的,所以我们必须保证模数是一个质数且不能太大。所以我们又得用上中国剩余定理, $ 999911658=2\times 3\times 4679\times 35617 $
于是我们分别求出在 $ mod\ 2 \ ,mod\ 3,mod \ 4679,mod \ 35617 $ 意义下的所有tot,然后就需要中国剩余定理解出我们真正的 $ mod \ 999911658 $ 意义下的tot是多少,然后就可以直接搞快速幂求答案了!
$ code: $
#include<iostream>
#include<cstdio>
#include<iomanip>
#include<algorithm>
#include<cstring>
#include<cstdlib>
#include<ctime>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<set>
#define ll long long
#define db double
#define mod 999911658
#define rg register int
using namespace std;
ll n,g,ans;
ll a[4];
ll jc[40005];
ll m[4]={2,3,4679,35617};
inline ll qr(){
char ch;
while((ch=getchar())<'0'||ch>'9');
ll res=ch^48;
while((ch=getchar())>='0'&&ch<='9')
res=res*10+(ch^48);
return res;
}
inline ll ksm(ll x,ll y,ll p){
ll res=1; x%=p;
while(y){
if(y&1)res=res*x%p;
x=x*x%p; y>>=1;
}return res;
}
inline ll c(ll x,ll y,ll p){ //组合数
if(x<y)return 0;
return jc[x]%p*ksm(jc[y],p-2,p)%p*ksm(jc[x-y],p-2,p)%p;//现求逆元
}
inline ll lc(ll x,ll y,ll p){ //卢卡斯
if(x<y)return 0; if(!x)return 1;
return c(x%p,y%p,p)*lc(x/p,y/p,p)%p;
}
int main(){
//freopen(".in","r",stdin);
//freopen(".out","w",stdout);
n=qr(); g=qr();
if(n==mod+1||g==mod+1){//特判
puts("0"); return 0;
}
for(rg k=0;k<4;++k){ jc[0]=jc[1]=1; //
for(rg i=2;i<=40000;++i)jc[i]=jc[i-1]*i%m[k]; //求出阶乘
for(rg i=1,j=sqrt(n);i<=j;++i){ //枚举约数
if(n%i!=0)continue;
a[k]=(a[k]+lc(n,i,m[k]))%m[k];
if(n==i*i)continue;
a[k]=(a[k]+lc(n,n/i,m[k]))%m[k];//n/i是较大的约数
}
}
for(rg i=0;i<4;++i)
ans=(ans+a[i]*(mod/m[i])%mod*ksm(mod/m[i],m[i]-2,m[i]))%mod;//中国剩余定理
printf("%lld\n",ksm(g,ans,mod+1));
return 0;
}
[SDOI2010]古代猪文 (欧拉,卢卡斯,中国剩余)的更多相关文章
- 【题解】P2480 [SDOI2010]古代猪文 - 卢卡斯定理 - 中国剩余定理
P2480 [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 ...
- 1951: [Sdoi2010]古代猪文
1951: [Sdoi2010]古代猪文 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 2171 Solved: 904[Submit][Status] ...
- BZOJ 1951: [Sdoi2010]古代猪文 [Lucas定理 中国剩余定理]
1951: [Sdoi2010]古代猪文 Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 2194 Solved: 919[Submit][Status] ...
- 洛咕 P2480 [SDOI2010]古代猪文
洛咕 P2480 [SDOI2010]古代猪文 题目是要求\(G^{\sum_{d|n}C^d_n}\). 用费马小定理\(G^{\sum_{d|n}C^d_n\text{mod 999911658} ...
- 【BZOJ1951】[SDOI2010]古代猪文
[BZOJ1951][SDOI2010]古代猪文 题面 bzoj 洛谷 题解 题目实际上是要求 $ G^{\sum d|n\;C_n^d}\;mod \; 999911659 $ 而这个奇怪的模数实际 ...
- 【BZOJ1951】[Sdoi2010]古代猪文 Lucas定理+CRT
[BZOJ1951][Sdoi2010]古代猪文 Description 求$X=\sum\limits_{d|n}C_n^d$,$Ans=G^X (\mod 999911659)$. Input 有 ...
- 洛谷 P2480 [SDOI2010]古代猪文 解题报告
P2480 [SDOI2010]古代猪文 题目背景 "在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心--" ...
- 【bzoj1951】: [Sdoi2010]古代猪文 数论-中国剩余定理-Lucas定理
[bzoj1951]: [Sdoi2010]古代猪文 因为999911659是个素数 欧拉定理得 然后指数上中国剩余定理 然后分别lucas定理就好了 注意G==P的时候的特判 /* http://w ...
随机推荐
- const,static,volatile关键字的作用
const关键字: 1.欲阻止一个变量被改变,可使用const,在定义该const变量时,需先初始化,以后就没有机会改变他了: 2.对指针而言,可以指定指针本身为const,也可以指定指针所指的数据为 ...
- BZOJ1895Pku3580 supermemo——非旋转treap
题目描述 给出一个初始序列fA1;A2;:::Ang,要求你编写程序支持如下操作: 1. ADDxyD:给子序列fAx:::Ayg的每个元素都加上D.例如对f1,2, 3,4,5g执行"AD ...
- 经典Java面试题收集
1.面向对象的特征有哪些方面? 答:面向对象的特征主要有以下几个方面: 抽象:抽象是将一类对象的共同特征总结出来构造类的过程,包括数据抽象和行为抽象两方面.抽象只关注对象有哪些属性和行为,并不关注这些 ...
- day8 笔记
文件操作的最简单步骤open():打开文件,将句柄赋值给一个变量 read()write()等:操作文件 close():关闭文件,一定要关闭文件 ps:python会帮助你保存数据关闭文件,但是要在 ...
- IDEA上传码云报错Push rejected: Push to origin/master was rejected
原因是README.md文件冲突,码云上在创建项目的时候不要初始化README.md,然后再用IDEA上传
- Sublime text3 插件LiveReload 实现实时预览
1.首先要安装插件LiveReload Sublime text3. 菜单 preferences->packages control,输入install.. 回车,输入LiveReload回车 ...
- LOJ #6435. 「PKUSC2018」星际穿越(倍增)
题面 LOJ#6435. 「PKUSC2018」星际穿越 题解 参考了 这位大佬的博客 这道题好恶心啊qwq~~ 首先一定要认真阅读题目 !! 注意 \(l_i<r_i<x_i\) 这个条 ...
- mycat实现简单的mysql集群负载均衡
什么是mycat呢? 简单理解为一个MySQL中间件,它支持分流.基于心跳的自动故障切换,支持读写分离,支持mysql主从,基于Nio管理线程的高并发… 详见官网:http://www.mycat.i ...
- Canvas与javaScript特效笔记
第六章 Canvas与javaScript特效笔记 q <canvas>标签的用途 HTML5 canvas 提供了通过 JavaScript 绘制图形的方法,此方法使用简单但功能强 ...
- [luogu2144][bzoj1002][FJOI2007]轮状病毒【高精度+斐波那契数列+基尔霍夫矩阵】
题目描述 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2个原子之间的边表示这2个原子之间的信息通道.如下图所示 N轮状病 ...