Submit | All submissions | Best solutions | Back to list |
SKEY - The SKey |
It is the 10-th ACM Egyptian National Programming Contest and Mostafa S., the chief judge, started to prepare for the problem set. In previous years, a chief judge used to ask problems’ setters to use his public key to encrypt the data so that they keep everything related to the problems secured. Unfortunately, the RSA algorithm was broken 2 weeks ago and Mostafa decided to invent a temporary algorithm till someone finds a new robust approach for encrypting/decrypting plaintext. After finding the algorithm, Mostafa met the judges and described the new encryption algorithm for them and gave them an equation to generate a key which the algorithm depends on. The key is generated through the following equation:
SKEY = (M * SUM [1 / A^K (from k = 0 to k = N)] ) % P
A, N and P are integers and P is a prime number that is co-prime with A (e.g. gcd(A, P) = 1). Furthermore M is a very large number (millions of digits) generated to be divisible by . For example given: A = 3, N = 2, P = 7 and M = 18, then the skey value is:
(18 * (1/1 + 1/3 + 1/9) ) % 7 = 26 % 7 = 5.
Unfortunately, sending extremely large numbers for M in the emails between judges is impractical. Luckily, a property of the modulus operator is: (A*B)%X = (A%X * B%X) %X.
Hence, we still can find our way to evaluate the skey by replacing M with M%P.
Given A, N, P, M%P, kindly help the chief judge with writing a code to compute the SKey.
Input Specification:
The first line of input contains an integer T that represents the number of test cases, then follow T lines each contains only four integer numbers A, N, P where 1 ≤ A ≤ 2147483647, 0 ≤ N ≤ 2147483647, 2 ≤ P ≤ 2147483647 and 0 ≤ M%P < P.
Output Specification:
For each test case, output a single line of output in the form “Case K: SKey” where K is the number of the test case and Skey is as defined in the problem statement. Check sample below for the format.
Sample input:
1
3 2 7 4
Sample Output:
Case 1: 5
Added by: | Mostafa Saad Ibrahim |
Date: | 2011-11-13 |
Time limit: | 1.649s |
Source limit: | 50000B |
Memory limit: | 1536MB |
Cluster: | Cube (Intel G860) |
Languages: | All except: ASM64 |
Resource: | 10th Egyptian Collegiate Programming Contest |
hide comments
2023-11-25 18:15:37
any hint? |
|
2023-11-25 14:00:02
222222230 |
|
2011-11-14 16:23:54 Miguel Oliveira
what is the answer for 3 2 1000000009 4 ? |