-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathbigMod.cpp
More file actions
39 lines (30 loc) · 680 Bytes
/
Copy pathbigMod.cpp
File metadata and controls
39 lines (30 loc) · 680 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#include<bits/stdc++.h>
using namespace std;
long long bigMod(long long,long long,long long);
int main () {
long long base,power, mod;
printf("Enter base:");
scanf("%d",&base);
printf("Enter power:");
scanf("%d",&power);
printf("Enter mod:");
scanf("%d",&mod);
long long res=bigMod(base,power,mod);
printf("%d\n",res);
return 0;
}
long long bigMod(long long b, long long p, long long m) {
if(p==0) {
return 1;
}
else if(p%2==0) {
long long tmp=bigMod(b,p/2,m);
return (tmp*tmp)%m;
}
else {
long long x,y;
x=b%m;
y=bigMod(b,p-1,m);
return (x*y)%m;
}
}