luogu_2480: 古代猪文
洛谷:2480古代猪文
题意描述:
- 给定两个整数\(N,G\),求$G{\sum_{k|n}C_nk}\ mod\ 999911659 $。
数据范围:
- \(1\leq N\leq 10^9,1\leq G\leq 10^9\)。
思路:
- 对于这样一个式子,暴力肯定是不可能的,所以我们先来挖掘一些性质。
- 模数\(999911659\)是一个质数,我们可以想到对这个式子进行欧拉降幂。
- 我们可以得到式子:
- \(G^{\sum_{k|n}C_n^k}\equiv\ G^{\sum_{k|n}C_n^kmod\varphi(999911659)}\ mod(999911659)\)。
- 只要当我们求出来指数是多少的时候,那么此时整个结果就变得十分明了了,我们只需要快速幂一下就可以得出结果。
- 所以接下来我们的重心在于解\(\sum_{k|n}C_n^kmod\ \varphi(mod)\)。
- 对于这样一个式子,我们可以看看\(\varphi(mod)\)是多少。
- 因为\(mod=999911659\)是一个质数,那么他对应的\(\varphi(mod)=999911658\)。
- 那么我们这时候的解就变成了解\(\sum_{k|n}C_n^kmod\ \varphi(999911658)\)。
- 因为\(n\)很大,所以不管怎么算都是很不划算的,我们手里能用的工具只有\(lucas\)定理,但是\(lucas\)定理要求模数为质数,这时候我们研究一下\(999911658\)。
- 我们发现他虽然不是质数,但是对其质因数分解后,可以发现\(999911658=2*3*4679*35617\),四个质数相乘。(出题人设计的真的是太巧妙了。)
- 于是将上式改写为\(\sum_{k|n}C_n^kmod\ \varphi(2*3*4679*35617)\)。
- 到了这里,似乎就有解头了,因为我们得到了质数,同时对于组合数可以用\(lucas\)定理来求解。但接下来要怎么考虑呢。因为毕竟上式你不能拆成\(原式\%2*原式\%3,...\)。
- 于是我们可以这么考虑,首先设上式为\(x\)。
- \(x\equiv num\ mod(2*3*4679*35617)\),其中\(num\)为上式的最小正整数解。
- 对于这样一个式子,我们可以拆分成:
- \(x\equiv num\ mod(2)\)
- \(x\equiv num\ mod(3)\)
- \(x\equiv num\ mod(4679)\)
- \(x\equiv num\ mod(35617)\)
- 可以假设:
- \(num\%2=a_1\)
- \(num\%3=a_2\)
- \(num\%4679=a_3\)
- \(num\%35617=a_4\)
- 又因为\(num\)与\(x\)同余,所以有:
- \(x\%2=a_1\)
- \(x\%3=a_2\)
- \(x\%4679=a_3\)
- \(x\%35617=a_4\)
- 对于\(a_i\)可以利用\(lucas\)快速求解,对于\(x\)可以使用中国剩余定理求解。
- 假设中国剩余定理求得的结果为\(ans\),最终结果就是:
- \(G^{ans}\ mod\ 999911659\)。
注意事项:
- 可能到了这里就觉得这题能完美解决了,但是其实还有一个小的点需要我们注意,那就是虽然\(mod=999911659\)是一个质数,但是\(g\)的范围很大,有可能\(g\)是\(999911659\)的倍数,那么不互质就不可以进行常规的欧拉降幂了。
- 那这里提供两种解决方案。
- 首先可以一进来就特判一下,看看\(g\%999911659==0\)否,我们可以特判掉这种情况。
- 第二种方案可以尝试采用拓展欧拉定理,先来复习一下:
- 当\(a,n\)不互质时:
- 当\(b\geq \varphi(n)\),有\(a^b\equiv a^{b\mod\varphi(n)+\varphi(n)}\)。
- 当\(b<\varphi(n)\),有\(a^b\equiv a^{b\mod\varphi(n)}\)。
- 那这时候情况很尴尬啊,我们不知道上式的那个组合数求和有多大。
- 但是对于本题,我们可以无脑的采用第一种情况。即\(a^b\equiv a^{b\mod\varphi(n)+\varphi(n)}\)。
- 因为首先当\(b\)非常大且超过\(\varphi(n)\)时,那么式子显然成立。
- 但是当不那么大的时候,对于原式的\(mod==999911659\),其实应该采用第二种情况,但是因为\(mod\)是一个质数,根据欧拉定理\(a^{\varphi(n)}\equiv1mod(n)\),其实加上去也就相当于是乘了一个 \(1\),对结果没有影响。
- 当\(a,n\)不互质时:
代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int mod = 999911659; //是一个质数
ll g, n, prime[10], a[10]; /*
999911658分解质因数结果为 2,3,4679,35617
*/ ll factor[1600], cnt;
void divide(ll x)
{
for(ll i = 1; i <= x / i; i++)
{
if(x % i == 0)
{
factor[++cnt] = i;
if(i != n / i) factor[++cnt] = n / i;
}
}
} ll qmi(ll a, ll b, ll p)
{
ll res = 1; res %= p;
while(b)
{
if(b & 1) res = res * a % p, res %= p;
a = a % p * a % p;
a %= p;
b >>= 1;
}
return res % p;
} ll C(ll a, ll b, ll p)
{
if(b > a) return 0;
if(b > a - b) b = a - b;
ll x = 1, y = 1;
for(int i = 0; i < b; i++)
{
x = x * (a - i) % p;
y = y * (i + 1) % p;
}
return x * qmi(y, p-2, p);
} ll lucas(ll a, ll b, ll p)
{
if(b == 0) return 1;
return C(a%p, b%p, p) * lucas(a/p, b/p, p) % p;
} ll exgcd(ll a, ll b, ll &x, ll &y)
{
if(b == 0) {x = 1; y = 0; return a;}
ll d = exgcd(b, a % b, y, x);
y -= a / b * x;
return d;
} ll crt()
{
ll res = 0;
for(int i = 1; i <= 4; i++)
res = (res + a[i] * (mod-1)/prime[i] % (mod-1) * qmi((mod-1)/prime[i], prime[i]-2, prime[i])) % (mod-1);
return res;
} int main()
{
cin >> n >> g;
/*
if(g % mod == 0)
{
puts("0");
return 0;
}
*/
divide(n);
memset(a, 0, sizeof a);
memset(prime, 0, sizeof prime);
prime[1] = 2; prime[2] = 3;
prime[3] = 4679; prime[4] = 35617; for(int i = 1; i <= 4; i++)
{
ll tmp = 0;
for(int j = 1; j <= cnt; j++)
{
ll x = factor[j];
tmp += lucas(n, x, prime[i]) % prime[i];
tmp %= prime[i];
}
a[i] = tmp;
}
ll x = crt();
//cout << qmi(g, x, mod) << endl;
cout << qmi(g, x + mod - 1, mod) << endl;
return 0;
}
luogu_2480: 古代猪文的更多相关文章
- BZOJ-1951 古代猪文 (组合数取模Lucas+中国剩余定理+拓展欧几里得+快速幂)
数论神题了吧算是 1951: [Sdoi2010]古代猪文 Time Limit: 1 Sec Memory Limit: 64 MB Submit: 1573 Solved: 650 [Submit ...
- 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] ...
- 古代猪文:数论大集合:欧拉定理,exgcd,china,逆元,Lucas定理应用
/* 古代猪文:Lucas定理+中国剩余定理 999911658=2*3*4679*35617 Lucas定理:(m,n)=(sp,tp)(r,q) %p 中国剩余定理:x=sum{si*Mi*ti} ...
- [SDOI2010]古代猪文 (欧拉,卢卡斯,中国剩余)
[SDOI2010]古代猪文 \(solution:\) 这道题感觉综合性极强,用到了许多数论中的知识: 质因子,约数,组合数 欧拉定理 卢卡斯定理 中国剩余定理 首先我们读题,发现题目需要我们枚举k ...
- 洛咕 P2480 [SDOI2010]古代猪文
洛咕 P2480 [SDOI2010]古代猪文 题目是要求\(G^{\sum_{d|n}C^d_n}\). 用费马小定理\(G^{\sum_{d|n}C^d_n\text{mod 999911658} ...
- BZOJ 1951 【SDOI2010】 古代猪文
题目链接:古代猪文 好久没写博客了,这次就先写一篇吧…… 题面好鬼……概括起来就是:给出\(N,G(\leqslant 10^9)\),求:\[G^{\sum_{d|n}\binom{n}{d}} \ ...
- 【BZOJ1951】[SDOI2010]古代猪文
[BZOJ1951][SDOI2010]古代猪文 题面 bzoj 洛谷 题解 题目实际上是要求 $ G^{\sum d|n\;C_n^d}\;mod \; 999911659 $ 而这个奇怪的模数实际 ...
随机推荐
- 【转】ubuntu16.04安装Vivado 2017.4 教程
ubuntu16.04安装Vivado 2017.4 教程 2017-12-28 20:59:48 wmyan 阅读数 11794 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协 ...
- MySQL数据库 : 高级查询
根据某个字段删除重复的数据, 只保留一条: 比如uuid字段有重复的, 需要只保留一条数据, 让uuid字段不能重复, 则首先 group by uuid 查出所有数据的id最小的那条数据,作为dt表 ...
- Jaeger接入Python应用:jaeger-client-python【非完全教程】
目录 Jaeger接入Python应用 1. 安装 jaeger-client 2. (示例)创建 Tracer 对象,并通过 Tracer 对象创建 Span 来追踪业务流程. 3. 初始化和配置 ...
- 像修改本机代码一样修改远端服务器的PHP网站
映射vps目录到自己电脑的摸索记录 最近拿discuz做了一个网站,需要修改模板文件之类的,还需要调试微信和QQ登陆的接口.都是些位置零散的小修改,但是有些需要在线上才能调试(QQ微信的oauth登陆 ...
- 安装oracle时出现的问题
数据库引擎和几个功能安装失败后 ,重新再装还是一样,好不容易全部功能装完成后结果发现登录不了oracle!!!!!!!!!!!!! 气死人,搞了一上午才发现原来是微软账号在搞事,登录本地管理员账户就 ...
- Go是如何生活在内存条里的【译】
原文:A visual guide to Go Memory Allocator from scratch (Golang) 当我第一次开始试图了解 Go 的内存分配器时,觉得它真令人抓狂.所有的所有 ...
- .Net IOC框架入门之——Unity
一.概述 IOC:英文全称:Inversion of Control,中文名称:控制反转,它还有个名字叫依赖注入(Dependency Injection). 作用:将各层的对象以松耦合的方式组织在一 ...
- java包装类和值类型的关系
java包装类总是让人疑惑 它与值类型到底是怎么样一种关系? 本文将以int和Integer为例来探讨它们的关系 java值类型有int short char boolean byte long fl ...
- 2019 农信互联java面试笔试题 (含面试题解析)
本人5年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.农信互联等公司offer,岗位是Java后端开发,因为发展原因最终选择去了农信互联,入职一年时间了,也成为了面 ...
- navicat2059错误的解决
1.输入mysql -uroot -p登陆mysql 2.登录成功以后使用ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD ...