forked from kdn251/interviews
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathModex.java
executable file
·49 lines (44 loc) · 1.47 KB
/
Modex.java
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
40
41
42
43
44
45
46
47
48
49
/**
* Many well-known cryptographic operations require modular exponentiation. That is, given integers x,
* y and n, compute x
* y mod n. In this question, you are tasked to program an efficient way to execute
* this calculation.
* Input
* The input consists of a line containing the number c of datasets, followed by c datasets, followed by a
* line containing the number ‘0’.
* Each dataset consists of a single line containing three positive integers, x, y, and n, separated by
* blanks. You can assume that 1 < x, n < 2
* 15 = 32768, and 0 < y < 2
* 31 = 2147483648.
* Output
* The output consists of one line for each dataset. The i-th line contains a single positive integer z such
* that
* z = x
* y mod n
* for the numbers x, y, z given in the i-th input dataset.
* Sample Input
* 2
* 2 3 5
* 2 2147483647 13
* 0
* Sample Output
* 3
* 11
*/
//https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem=3671
import java.math.BigInteger;
import java.util.Scanner;
public class Modex {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int numberOfTestCases = input.nextInt();
while (numberOfTestCases != 0) {
BigInteger x = input.nextBigInteger();
BigInteger y = input.nextBigInteger();
BigInteger n = input.nextBigInteger();
BigInteger result = x.modPow(y, n);
System.out.println(result);
numberOfTestCases--;
}
}
}