Advertisement
Guest User

Untitled

a guest
Mar 29th, 2020
74
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.48 KB | None | 0 0
  1. #include <iostream>
  2. #include <fstream>
  3. #include <vector>
  4. #include <string>
  5. #include <algorithm>
  6. #include <set>
  7. #include <map>
  8. #include <cmath>
  9. #include <cstring>
  10. #include <ctime>
  11. #include <unordered_map>
  12. #include <iomanip>
  13. #include <complex>
  14. #include <cassert>
  15. #include <queue>
  16. #include <random>
  17. #include <chrono>
  18.  
  19. using namespace std;
  20.  
  21. #define fi first
  22. #define se second
  23. #define pb push_back
  24. #define all(v) (v).begin(),(v).end()
  25. #define deb(a) cerr<< #a << "= " << (a)<<"\n";
  26.  
  27.  
  28. typedef long long ll;
  29. typedef unsigned long long ull;
  30. typedef unsigned int uint;
  31. typedef long double ld;
  32. typedef complex<double> base;
  33. typedef vector<int> vi;
  34. typedef pair<int,int> pii;
  35.  
  36. template<class T> ostream& operator<<(ostream& stream, const vector<T> v){ stream << "[ "; for (int i=0; i<(int)v.size(); i++) stream << v[i] << " "; stream << "]"; return stream; }
  37. ll fpow(ll x, ll p, ll m){ll r=1; for (;p;p>>=1){ if (p&1) r=r*x%m; x=x*x%m; } return r;}
  38. ll inv(ll a, ll b){ return a<2 ? a : ((a-inv(b%a,a))*b+1)/a%b; }
  39. int gcd(int a, int b){ if (!b) return a; return gcd(b,a%b);}
  40. ll gcd(ll a, ll b){ if (!b) return a; return gcd(b,a%b);}
  41.  
  42.  
  43.  
  44. int N,a[520][520];
  45. typedef vector<vi> matrix;
  46.  
  47. vector<matrix> get_r(matrix a){
  48. matrix b(a);
  49. vector<matrix> ans;
  50.  
  51. int i,j,k;
  52.  
  53. for (i=0; i<N; i++)
  54. for (j=0; j<N; j++)
  55. b[i][j]=a[i][j]%N;
  56.  
  57. bool all_p=1;
  58. for (j=0; j<N; j++)
  59. for (i=0; i<N; i++)
  60. all_p&=b[i][j]==j;
  61.  
  62.  
  63. if (!all_p){
  64. bool all_d=1;
  65.  
  66. for (i=0; i<N; i++){
  67. vector<int> arr = b[i];
  68.  
  69. sort(all(arr));
  70.  
  71. for (j=0; j<N; j++)
  72. all_d&=arr[j]==j;
  73. }
  74.  
  75. matrix cr=a;
  76. matrix bcopy=b;
  77.  
  78. if (!all_d){
  79. vector<vector<bool>> v(N,vector<bool>(N));
  80.  
  81.  
  82. for (j=0; j<N; j++){
  83. for (i=0; i<N; i++){
  84. for (k=0; k<N; k++){
  85. if (!v[k][b[i][j]]){
  86. cr[k][j]=a[i][j];
  87. v[k][b[i][j]]=1;
  88. bcopy[k][j]=b[i][j];
  89. break;
  90. }
  91. }
  92. }
  93. }
  94.  
  95. ans.pb(cr);
  96. }
  97.  
  98. b=bcopy;
  99. matrix cr_copy=cr;
  100.  
  101. for (i=0; i<N; i++){
  102. for (j=0; j<N; j++){
  103. cr[i][b[i][j]]=cr_copy[i][j];
  104. }
  105. }
  106.  
  107. ans.pb(cr);
  108.  
  109. }
  110.  
  111. int K=0;
  112.  
  113. for (i=0; i<N; i++)
  114. for (j=0; j<N; j++)
  115. a[i][j]=K++;
  116.  
  117. ans.pb(a);
  118.  
  119. return ans;
  120.  
  121. }
  122.  
  123. int main(){
  124. ios::sync_with_stdio(0);
  125. cin.tie(0);
  126. int T;
  127.  
  128. cin >> T;
  129. while (T--){
  130. int i,j;
  131. cin >> N;
  132.  
  133. for (i=1; i<=N; i++){
  134. for (j=1; j<=N; j++){
  135. cin >> a[i][j];
  136. }
  137. }
  138.  
  139. bool ok=1;
  140. int K=0;
  141. for (i=1; i<=N; i++)
  142. for (j=1; j<=N; j++)
  143. ok&=a[i][j]==++K;
  144.  
  145. if (ok){
  146. cout << 0 << "\n";
  147. continue;
  148. }
  149.  
  150.  
  151. matrix m(N,vi(N));
  152. for (i=0; i<N; i++)
  153. for (j=0; j<N; j++)
  154. m[i][j]=a[i+1][j+1]-1;
  155.  
  156. vector<matrix> f=get_r(m);
  157.  
  158.  
  159. /*for (i=0; i<N; i++)
  160. for (j=i+1; j<N; j++)
  161. swap(m[i][j],m[j][i]);
  162.  
  163. for (i=0; i<N; i++)
  164. for (j=0; j<N; j++){
  165. m[i][j]=(m[i][j]%N)*N+m[i][j]/N;
  166. }
  167.  
  168. vector<matrix> s=get_r(m);
  169. for (matrix m : s){
  170. for (i=0; i<N; i++)
  171. for (j=i+1; j<N; j++)
  172. swap(m[i][j],m[j][i]);
  173.  
  174. for (i=0; i<N; i++)
  175. for (j=0; j<N; j++){
  176. m[i][j]=(m[i][j]%N)*N+m[i][j]/N;
  177. }
  178. }
  179.  
  180. vector<matrix> ans;
  181. if (f.size()<s.size()) ans=f;
  182. else ans=s;*/
  183.  
  184. vector<matrix> ans=f;
  185. cout << "ans: " << ans.size() << "\n";
  186. for (matrix m : ans){
  187. for (i=0; i<N; i++,cout << "\n")
  188. for (j=0; j<N; j++)
  189. cout << m[i][j]+1 << " ";
  190. }
  191.  
  192. }
  193.  
  194.  
  195.  
  196.  
  197.  
  198.  
  199.  
  200. return 0;
  201.  
  202.  
  203. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement