Problem Description
求 a 的 b 次方对 p 取模的值。
Input Format
三个整数 a,b,p ,在同一行用空格隔开。
Output Format
输出一个整数,表示a^b mod p的值。
Scope of Data
0 ≤ a, b ≤ 109
1 ≤ p ≤ 109
Sample Input
3 2 7
Sample Output
2
Idea
Program Code
#include <iostream>
using namespace std;
long long int a, b, p;
int main()
{
cin >> a >> b >> p;
long long int ans = 1 % p; //此时模p是因为可能出现b为0且p为1情况
while(b)
{
if(b & 1) //位运算,判断最低位是否为1
ans = ans * a % p;
a = a * a % p; //b的每位都会变为之前的double,所以a需要平方
b >>= 1; //位运算,b向右移一位,即舍去最低位
}
cout << ans << endl;
return 0;
}
- If you have any questions,please feel free to communicate with me.