fork(3) download
  1. #include<bits/stdc++.h>
  2. #define pb(x) push_back(x)
  3. #define all(x) x.begin(), x.end()
  4. #define cout2(x, y) cout << x << " " << y << endl
  5. #define N 100004
  6.  
  7. using namespace std;
  8.  
  9.  
  10. unsigned long long q;
  11. vector<unsigned long long> v;
  12.  
  13. unsigned long long gcd(unsigned long long a, unsigned long long b){
  14. if(b == 0) return a;
  15. return gcd( b , a % b );
  16. }
  17.  
  18. long long mul(long long a,long long b,long long c){
  19. long long x = 0, y = a % c;
  20. while(b > 0){
  21. if(b%2 == 1){
  22. x = (x+y)%c;
  23. }
  24. y = (y*2)%c;
  25. b /= 2;
  26. }
  27. return x%c;
  28. }
  29.  
  30. long long modd(long long a,long long b,long long c){
  31. long long x=1,y=a;
  32. while(b > 0){
  33. if(b%2 == 1){
  34. x=mul(x,y,c);
  35. }
  36. y = mul(y,y,c);
  37. b /= 2;
  38. }
  39. return x%c;
  40. }
  41.  
  42. bool Miller(long long p,int iteration){
  43. if(p<2){
  44. return false;
  45. }
  46. if(p!=2 && p%2==0){
  47. return false;
  48. }
  49. long long s=p-1;
  50. while(s%2==0){
  51. s/=2;
  52. }
  53. for(int i=0;i<iteration;i++){
  54. long long a=rand()%(p-1)+1,temp=s;
  55. long long mod=modd(a,temp,p);
  56. while(temp!=p-1 && mod!=1 && mod!=p-1){
  57. mod=mul(mod,mod,p);
  58. temp *= 2;
  59. }
  60. if(mod!=p-1 && temp%2==0){
  61. return false;
  62. }
  63. }
  64. return true;
  65. }
  66.  
  67. unsigned long long rho(unsigned long long n){
  68.  
  69. if( n % 2 == 0 ) return 2;
  70. unsigned long long x = 2 , y = 2 , d = 1;
  71. int c = rand() % n + 1;
  72. while( d == 1 ){
  73. x = (mul( x , x , n ) + c)%n;
  74. y = (mul( y , y , n ) + c)%n;
  75. y = (mul( y , y , n ) + c)%n;
  76. if( x - y >= 0 ) d = gcd( x - y , n );
  77. else d = gcd( y - x , n );
  78. }
  79. return d;
  80. }
  81.  
  82. void factor(unsigned long long n){
  83. if (n == 1) return;
  84. if( Miller(n , 6) ){
  85. if(q != n) v.push_back(n);
  86. return;
  87. }
  88. unsigned long long divisor = rho(n);
  89. factor(divisor);
  90. factor(n/divisor);
  91. }
  92.  
  93. #define MOD 1000000007
  94.  
  95. int main(){
  96.  
  97. int tc = 0;
  98. scanf("%d", &tc);
  99.  
  100. while(tc--){
  101.  
  102. int n;
  103. scanf("%d", &n);
  104.  
  105. v.clear();
  106. long long A;
  107.  
  108. long long ans = 1;
  109. for(int i = 0; i < n; i++){
  110.  
  111. scanf("%lld", &A);
  112. q = 0;
  113.  
  114. factor(A);
  115. if(A >= MOD)A %= MOD;
  116.  
  117. ans = ans * A;
  118. if(ans >= MOD)ans %= MOD;
  119.  
  120.  
  121. }
  122.  
  123. sort(all(v));
  124. int ct = 1;
  125.  
  126. for(int i = 1; i < v.size(); i++){
  127.  
  128. if(v[i] == v[i - 1])ct++;
  129. else{
  130.  
  131. ct %= 3;
  132. if(v[i - 1] >= MOD)v[i - 1] %= MOD;
  133.  
  134. for(int j = 0; j < (3 - ct)%3; j++){
  135.  
  136. ans = ans * v[i - 1];
  137. if(ans >= MOD)ans %= MOD;
  138.  
  139. }
  140.  
  141. ct = 1;
  142.  
  143. }
  144. }
  145.  
  146. if(v.size() > 0){
  147.  
  148. ct %= 3;
  149. if(v.back() >= MOD)v.back() %= MOD;
  150.  
  151. for(int j = 0; j < (3 - ct)%3; j++){
  152.  
  153. ans = ans * v.back();
  154. if(ans >= MOD)ans %= MOD;
  155. }
  156. }
  157.  
  158. cout << ans << endl;
  159.  
  160. }
  161.  
  162. }
Time limit exceeded #stdin #stdout 5s 2824KB
stdin
10
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
100
999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087 999949000866995087
stdout
189614279