【SDOI 2010】 古代猪文
【题目链接】
https://www.lydsy.com/JudgeOnline/problem.php?id=1951
【算法】
欧拉定理+中国剩余定理 + lucas定理
【代码】
#include<bits/stdc++.h>
using namespace std;
#define MAXD 40000
typedef long long ll;
const ll P = ;
const ll m[] = {,,,}; ll i,j,n,q,cnt,ans,x;
ll a[],factor[];
ll fac[MAXD+][]; inline void exgcd(ll a,ll b,ll &x,ll &y)
{
if (b == )
{
x = ;
y = ;
} else
{
exgcd(b,a%b,y,x);
y -= a / b * x;
}
}
inline ll CRT()
{
int i;
ll res = ,M,T,x;
for (i = ; i < ; i++)
{
M = (P - ) / m[i];
exgcd(M,m[i],T,x);
T = (T % m[i] + m[i]) % m[i];
res = (res + (a[i] * M % (P - ) * T % (P - )) % (P - )) % (P - );
}
return res;
}
inline ll power(ll a,ll n,ll p)
{
ll b = a,res = ;
while (n)
{
if (n & ) res = res * b % p;
b = b * b % p;
n >>= ;
}
return res;
}
inline void init()
{
int i,j;
for (i = ; i < ; i++) fac[][i] = ;
for (i = ; i <= MAXD; i++)
{
for (j = ; j < ; j++)
{
fac[i][j] = fac[i-][j] * i % m[j];
}
}
}
inline ll C(ll x,ll y,ll p)
{
if (x < y) return ;
if (y == ) return ;
return fac[x][p] * power(fac[y][p]*fac[x-y][p]%m[p],m[p]-,m[p]) % m[p];
}
inline ll lucas(ll x,ll y,ll p)
{
if (y == ) return ;
else return lucas(x/m[p],y/m[p],p) * C(x%m[p],y%m[p],p) % m[p];
}
int main()
{ scanf("%lld%lld",&n,&q);
if (q == P)
{
printf("0\n");
return ;
}
cnt = ;
for (i = ; i <= sqrt(n); i++)
{
if (n % i == )
{
factor[++cnt] = i;
if (i * i != n) factor[++cnt] = n / i;
}
}
init();
for (i = ; i <= cnt; i++)
{
for (j = ; j < ; j++)
{
a[j] = lucas(n,factor[i],j);
}
x = (x + CRT()) % (P - );
}
ans = power(q,x,P);
printf("%lld\n",ans); return ; }
【SDOI 2010】 古代猪文的更多相关文章
- 【数学/扩展欧几里得/Lucas定理】BZOJ 1951 :[Sdoi 2010]古代猪文
Description “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边 ...
- [ SDOI 2010 ] 古代猪文
\(\\\) Description 一句话题意: 设 \(x=\sum_{d|n} C_n^d\),求 \(G^x\pmod {999911659}\) . 从原题面大段语文中其实不难推出所求. \ ...
- 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}} \ ...
随机推荐
- Tour UVA - 1347
John Doe, a skilled pilot, enjoys traveling. While on vacation, he rents a small plane and starts vi ...
- Android第三方微博、无线传输、动画特效、商城应用等源码
Android精选源码 Android汽车助手源码 一个酷炫的Android特效源码 新浪微博的第三方客户端.UI遵循Material Design. Android实现旋转木马布局多种效果 Andr ...
- 苹果双系统win8.1遇到的一些问题
MacBook air是一款不错的电脑,详细没研究就不叙述好与坏了.只此记录自己使用这款笔记本遇到的问题. 一.安装双系统win8.1 1.下载镜像文件—>拷贝到ios内存中,一个8GU盘.ht ...
- Android贝塞尔曲线应用-跳动的水滴
主要通过6个控制点实现. val startPoint = PointF() val endPoint = PointF() val control1 = PointF() val control2 ...
- 压缩映射:简单最邻近搜索-(SLH)Simple Linear Hash
Compact Projection: Simple and Efficient Near Neighbor Search with Practical memory Requirement Auto ...
- 相机标定:PNP基于单应面解决多点透视问题
利用二维视野内的图像,求出三维图像在场景中的位姿,这是一个三维透视投影的反向求解问题.常用方法是PNP方法,需要已知三维点集的原始模型. 本文做了大量修改,如有不适,请移步原文: ...
- 【sqli-labs】 less23 Error based - strip comments (GET型基于错误的去除注释的注入)
. 加单引号报错 加# http://localhost/sqli-labs-master/Less-23/?id=1'%23 错误没有改变,推测过滤了# 查看源码发现# -- 都被替换掉了 那么可用 ...
- ESP32 开发笔记(十二)LittlevGL 添加自定义字体和物理按键
LittlevGL 添加自定义字体获取字库 ttf 文件可以从一些网站上获取字库文件,比如请注意字体许可证 生成源文件使用 LittlevGL 提供的字库文件转换工具,将 ttf 字库文件转换为源文件 ...
- HLPP算法 一种高效的网络最大流算法
#include <algorithm> #include <cstdio> #include <cctype> #include <queue> #d ...
- python笔记之json报错
写爬虫的过程中不免遇到处理json数据的情况,今天在爬取新华网新闻数据时发现使用json.loads函数时报错: json.decoder.JSONDecodeError: Expecting val ...