题目描述
求 a 的 b 次方对 p 取模的值,其中 1≤a,b,p≤109
输入
三个用空格隔开的整数a,b和p。
输出
一个整数,表示ab mod p的值。
样例输入 Copy
2 3 9样例输出 Copy
8
快速幂求a^b
int kspow(int a,int b)
{
int ans=1;
while(b)
{
if(b&1) ans*=a;
a*=a;
b>>=1;
}
return ans;
}
代码:
#include <iostream>
using namespace std;
int main()
{
long long a,b,p,ans;
cin>>a>>b>>p;
ans=1%p;
while(b)
{
if(b&1) ans=ans*a%p;
a=a*a%p;
b>>=1;
}
cout<<ans;
return 0;
}