费马小定理 快速幂


题意求一个超级大的数N,分成i种方案的总和,这个有个隔板法的公式,结果为2^(n-1)-1,因为n太大用费马小定理 费马小定理,a^(p-1)=1(%p)
当p和a互质的时候,把n%(p-1)和n等效。

#include<iostream>
#include<string>
using namespace std;
const	int mod=1e9+7;
int qs(int a,int b,int n)
{
	int res=1;
	while(b)
	{
		if(b&1)		res=(long long )res*a%n;
		a=(long long)a*a%n;
		b>>=1;
				
	}
	return res;
}
long long convert(string s)
{
	long	long ans=0;
	for(int i=0;i<s.size();i++)
	ans=(ans*10+(s[i]-'0'))%(mod-1);
	return ans;
}
int main()
{
	string s;
	while(cin>>s)
	{
		long long n=convert(s);
		cout<<qs(2,n-1,mod)<<endl;
	}
}
全部评论

相关推荐

书海为家:实习是成为大厂正式员工很好的敲门砖,看您的简历中有一段实习经历,挺好的。我来给一点点小建议,因为毕竟还在学校不像工作几年的老鸟有丰富的项目经验,面试官在面试在校生的时候更关注咱们同学的做事逻辑和思路,所以最好在简历中描述下自己实习时做过项目的完整过程,比如需求怎么来的,你对需求的解读,你想到的解决办法,遇到困难如何找人求助,最终项目做成了什么程度,你从中收获了哪些技能,你有什么感悟。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务