Algorithm
Gregor is learning about RSA cryptography, and although he doesn't understand how RSA works, he is now fascinated with prime numbers and factoring them.
Gregor's favorite prime number is P. Gregor wants to find two bases of P. Formally, Gregor is looking for two integers a and b which satisfy both of the following properties.
- Pmoda=Pmodb, where xmody denotes the remainder when x is divided by y, and
- 2≤a<b≤P.
Help Gregor find two bases of his favorite prime number!
Each test contains multiple test cases. The first line contains the number of test cases t (1≤t≤1000).
Each subsequent line contains the integer P (5≤P≤109), with P guaranteed to be prime.
Your output should consist of t lines. Each line should consist of two integers a and b (2≤a<b≤P). If there are multiple possible solutions, print any.
2 17 5
3 5 2 4
The first query is P=17. a=3 and b=5 are valid bases in this case, because 17mod3=17mod5=2. There are other pairs which work as well.
In the second query, with P=5, the only solution is a=2 and b=4.
Code Examples
#1 Code Example with C++ Programming
Code -
C++ Programming
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define endl '\n'
#define debug(n) cout<<(n)<<endl;
const ll INF = 2e18 + 99;
int main(){
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int t;
cin>>t;
int n;
while(t--){
cin>>n;
n--;
cout<<2<<" "<<n<<endl;
}
}
Copy The Code &
Try With Live Editor
Input
17
5
Output
> 2 4
Demonstration
Codeforcess Solution 1549-A A. Gregor and Cryptography ,C++, Java, Js and Python,1549-A,Codeforcess Solution