zoukankan      html  css  js  c++  java
  • [SDOI2010]古代猪文

    Description
    “在那山的那边海的那边有一群小肥猪。他们活泼又聪明,他们调皮又灵敏。他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边海的那边的某片风水宝地曾经存在过一个猪王国。猪王国地理位置偏僻,实施的是适应当时社会的自给自足的庄园经济,很少与外界联系,商贸活动就更少了。因此也很少有其他动物知道这样一个王国。 猪王国虽然不大,但是土地肥沃,屋舍俨然。如果一定要拿什么与之相比的话,那就只能是东晋陶渊明笔下的大家想象中的桃花源了。猪王勤政爱民,猪民安居乐业,邻里和睦相处,国家秩序井然,经济欣欣向荣,社会和谐稳定。和谐的社会带给猪民们对工作火红的热情和对未来的粉色的憧憬。 小猪iPig是猪王国的一个很普通的公民。小猪今年10岁了,在大肥猪学校上小学三年级。和大多数猪一样,他不是很聪明,因此经常遇到很多或者稀奇古怪或者旁人看来轻而易举的事情令他大伤脑筋。小猪后来参加了全猪信息学奥林匹克竞赛(Pig Olympiad in Informatics, POI),取得了不错的名次,最终保送进入了猪王国大学(Pig Kingdom University, PKU)深造。 现在的小猪已经能用计算机解决简单的问题了,比如能用P++语言编写程序计算出A + B的值。这个“成就”已经成为了他津津乐道的话题。当然,不明真相的同学们也开始对他刮目相看啦~ 小猪的故事就将从此展开,伴随大家两天时间,希望大家能够喜欢小猪。 题目描述 猪王国的文明源远流长,博大精深。 iPig在大肥猪学校图书馆中查阅资料,得知远古时期猪文文字总个数为N。当然,一种语言如果字数很多,字典也相应会很大。当时的猪王国国王考虑到如果修一本字典,规模有可能远远超过康熙字典,花费的猪力、物力将难以估量。故考虑再三没有进行这一项劳猪伤财之举。当然,猪王国的文字后来随着历史变迁逐渐进行了简化,去掉了一些不常用的字。 iPig打算研究古时某个朝代的猪文文字。根据相关文献记载,那个朝代流传的猪文文字恰好为远古时期的k分之一,其中k是N的一个正约数(可以是1和N)。不过具体是哪k分之一,以及k是多少,由于历史过于久远,已经无从考证了。 iPig觉得只要符合文献,每一种能整除N的k都是有可能的。他打算考虑到所有可能的k。显然当k等于某个定值时,该朝的猪文文字个数为N / k。然而从N个文字中保留下N / k个的情况也是相当多的。iPig预计,如果所有可能的k的所有情况数加起来为P的话,那么他研究古代文字的代价将会是G的P次方。 现在他想知道猪王国研究古代文字的代价是多少。由于iPig觉得这个数字可能是天文数字,所以你只需要告诉他答案除以999911659的余数就可以了。

    Input
    有且仅有一行:两个数N、G,用一个空格分开。

    Output
    有且仅有一行:一个数,表示答案除以999911659的余数。

    Sample Input
    4 2

    Sample Output
    2048

    HINT
    10%的数据中,(1leqslant Nleqslant 50)
    20%的数据中,(1leqslant Nleqslant 10^3)
    40%的数据中,(1leqslant Nleqslant 10^5)
    100%的数据中,(1leqslant Gleqslant 10^9,1leqslant Nleqslant 10^9)


    题目要求(G^{sumlimits_{d|N}inom{N}{d}})

    但是直接求显然不好求,注意到答案%999911659,所以指数上需要%999911658

    (999911658=2 imes3 imes4679 imes35617)

    然后我们就可以分别对每个质数算出答案,然后用crt合并即可

    /*program from Wolfycz*/
    #include<cmath>
    #include<cstdio>
    #include<cstring>
    #include<iostream>
    #include<algorithm>
    #define inf 0x7f7f7f7f
    typedef long long ll;
    typedef long double ld;
    typedef unsigned int ui;
    typedef unsigned long long ull;
    template<typename T>inline T min(T x,T y){return x<y?x:y;}
    template<typename T>inline T max(T x,T y){return x>y?x:y;}
    inline char gc(){
    	static char buf[1000000],*p1=buf,*p2=buf;
    	return p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?EOF:*p1++;
    }
    template<typename T>inline T frd(T x){
    	int f=1; char ch=gc();
    	for (;ch<'0'||ch>'9';ch=gc())	if (ch=='-')    f=-1;
    	for (;ch>='0'&&ch<='9';ch=gc())	x=(x<<1)+(x<<3)+ch-'0';
    	return x*f;
    }
    template<typename T>inline T read(T x){
    	int f=1;char ch=getchar();
    	for (;ch<'0'||ch>'9';ch=getchar())	if (ch=='-')	f=-1;
    	for (;ch>='0'&&ch<='9';ch=getchar())	x=(x<<1)+(x<<3)+ch-'0';
    	return x*f;
    }
    inline void print(int x){
    	if (x<0)    putchar('-'),x=-x;
    	if (x>9)	print(x/10);
    	putchar(x%10+'0');
    }
    namespace Math{
    	int mlt(int a,int b,int p){
    		int res=1;
    		for (;b;b>>=1,a=1ll*a*a%p)	if (b&1)	res=1ll*res*a%p;
    		return res;
    	}
    	int gcd(int a,int b){return !b?a:gcd(b,a%b);}
    	void exgcd(int a,int b,int &x,int &y){
    		if (!b){x=1,y=0;return;}
    		exgcd(b,a%b,x,y);
    		int t=x; x=y,y=t-a/b*y;
    	}
    	int Ex_GCD(int a,int b,int c){
    		int d=gcd(a,b),x,y;
    		if (c%d)	return -1;
    		a/=d,b/=d,c/=d;
    		exgcd(a,b,x,y);
    		x=(1ll*x*c%b+b)%b;
    		return x;
    	}
    }
    const int N=4e4,Mod=999911659;
    int fac[N+10],inv[N+10];
    void prepare(int p){
    	fac[0]=inv[0]=inv[1]=1;
    	for (int i=1;i<p;i++)	fac[i]=1ll*fac[i-1]*i%p;
    	for (int i=2;i<p;i++)	inv[i]=1ll*(p-p/i)*inv[p%i]%p;
    	for (int i=1;i<p;i++)	inv[i]=1ll*inv[i-1]*inv[i]%p;
    }
    int C(int n,int m,int p){
    	if (n<m)	return 0;
    	if (n<p&&m<p)	return 1ll*fac[n]*inv[m]%p*inv[n-m]%p;
    	return 1ll*C(n/p,m/p,p)*C(n%p,m%p,p)%p;
    }
    int work(int n,int p){
    	prepare(p); int res=0;
    	for (int i=1;i*i<=n;i++){
    		if (n%i)	continue;
    		res=(res+C(n,i,p))%p;
    		if (i*i!=n)	res=(res+C(n,n/i,p))%p;
    	}
    	return res;
    }  
    int main(){
    	int N=read(0),G=read(0),_P=Mod-1,Ans=0;
    	static int P[4]={2,3,4679,35617};
    	for (int i=0;i<4;i++)	Ans=(Ans+1ll*Math::Ex_GCD(_P/P[i],P[i],1)*work(N,P[i])%_P*(_P/P[i])%_P)%_P;
    	printf("%d
    ",Ans?Math::mlt(G,Ans,Mod):0);
    	return 0;
    }
    
  • 相关阅读:
    验证SMTP工作过程
    FileZilla FTP服务器的安装和配置
    最后一块石头的重量
    不用加号的加法
    同构字符串
    最长公共子序列
    Telnet 验证HTTP工作过程
    矩阵的最小路径和
    子数组的最大累加和问题
    海思开发板——YOLOv3模型移植(4)
  • 原文地址:https://www.cnblogs.com/Wolfycz/p/10630211.html
Copyright © 2011-2022 走看看