【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}} \ ...
随机推荐
- 上传预览图片的插件jquery-fileupload
上传预览图片的插件jquery-fileupload github地址:https://github.com/blueimp/jQuery-File-Upload 中文文档:http://www.jq ...
- vue-router简单用法
路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容.Home按钮 => home 内容, ...
- JavaScript中变量的类型
变量的类型是指变量的值所属的数据类型,可以是数值型.字符串型和布尔型等,因为JavaScript是一种弱类型的程序语言,所以可以把任意类型的数据赋值给变量. 下面是一个关于变量类型的例子.在这个例子中 ...
- 【SQL】CASE与DECODE
1. case..when case..when语句用于按照条件返回查询结果,如当我们想把emp表的工资按照多少分成几个不同的级别,并分别统计各个级别的员工数.SQL语句如下: select (cas ...
- java反射_01
为什么要用反射? 举个栗子: package com.imooc.reflect; public class Work { // 定义一个word方法 public void word() { Sys ...
- SQLite-编译指示
SQLite – 编译指示 SQLite编译指示命令(PRAGMA)是一个特殊的命令是用于控制各种环境变量和状态标志在SQLite的环境.编译指示值可以读取,也可以根据需求设置. 语法: 查询当前的编 ...
- Ubuntu安装中文语言包
使用Ubuntu 默认的界面感觉不习惯,于是安装KDE界面. 1.安装kde 使用命令行: sudo apt-get install kubuntu-desktop 安装后发现不能使用中文, 在 se ...
- Java_Reflect反射
类是对象,类是java.lang.Class类的实例对象.There is a class named Class class Foo{} public class ClassDemo{ public ...
- python 字符串模糊匹配 Fuzzywuzzy
Python提供fuzzywuzzy模块,不仅可用于计算两个字符串之间的相似度,而且还提供排序接口能从大量候选集中找到最相似的句子. (1)安装 pip install fuzzywuzzy (2)接 ...
- null值处理
一,在实体类的上面加注解 import com.fasterxml.jackson.annotation.JsonInclude @JsonInclude(JsonInclude.Include.NO ...