sacgajcvs

Untitled

Oct 11th, 2020
121
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.15 KB | None | 0 0
  1. /*
  2. _____ _ _ _ _
  3. |_ _| |__ ___ / \ _ __ ___| |__ _ _| |
  4. | | | '_ \ / _ \ / _ \ | '_ \/ __| '_ \| | | | |
  5. | | | | | | __// ___ \| | | \__ \ | | | |_| | |
  6. |_| |_| |_|\___/_/ \_\_| |_|___/_| |_|\__,_|_|
  7.  
  8. */
  9. #include<bits/stdc++.h>
  10. #include <ext/pb_ds/assoc_container.hpp>
  11. #include <ext/pb_ds/tree_policy.hpp>
  12. #define ll long long
  13. #define pb push_back
  14. #define ppb pop_back
  15. #define endl '\n'
  16. #define mii map<ll,ll>
  17. #define msi map<string,ll>
  18. #define mis map<ll, string>
  19. #define rep(i,a,b) for(ll i=a;i<b;i++)
  20. #define repr(i,a,b) for(ll i=b-1;i>=a;i--)
  21. #define trav(a, x) for(auto& a : x)
  22. #define pii pair<ll,ll>
  23. #define vi vector<ll>
  24. #define vii vector<pair<ll, ll>>
  25. #define vs vector<string>
  26. #define all(a) (a).begin(),(a).end()
  27. #define F first
  28. #define S second
  29. #define sz(x) (ll)x.size()
  30. #define hell 1000000007
  31. #define lbnd lower_bound
  32. #define ubnd upper_bound
  33. #define max(a,b) (a>b?a:b)
  34. #define min(a,b) (a<b?a:b)
  35.  
  36. /* For Debugging */
  37. #define DEBUG cerr<<"\n>>>I'm Here<<<\n"<<endl;
  38. #define display(x) trav(a,x) cout<<a<<" ";cout<<endl;
  39. #define what_iss(x) cerr << #x << " = " << x << endl;
  40. #define what_is(x) cerr << #x << " = " << x << " ";
  41.  
  42. std::mt19937_64 rng(std::chrono::steady_clock::now().time_since_epoch().count());
  43. #define ordered_set tree<ll, null_type,less<ll>, rb_tree_tag,tree_order_statistics_node_update>
  44. #define TIME cerr << "\nTime elapsed: " << setprecision(5) <<1000.0 * clock() / CLOCKS_PER_SEC << "ms\n";
  45. #define DECIMAL(n) cout << fixed ; cout << setprecision(n);
  46. #define FAST ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
  47. using namespace __gnu_pbds;
  48. using namespace std;
  49. #define PI 3.141592653589793
  50. #define N 100005
  51.  
  52. void solve()
  53. {
  54. ll n;
  55. cin >> n;
  56. vector<vi> v(n,vi(n));
  57. rep(i,0,n) {
  58. rep(j,0,n) {
  59. cin >> v[i][j];
  60. }
  61. }
  62. vector<vi> tmp(n,vi(n,0));
  63. map<ll,set<ll>> mar[n],mac[n];
  64. rep(i,0,n) {
  65. rep(j,0,n) {
  66. mar[i][v[i][j]].insert(j);
  67. }
  68. trav(j,mar[i]) {
  69. if(sz(j.S)>1) {
  70. trav(k,j.S) {
  71. tmp[i][k]++;
  72. }
  73. }
  74. }
  75. }
  76. rep(i,0,n) {
  77. rep(j,0,n) {
  78. mac[i][v[j][i]].insert(j);
  79. }
  80. trav(j,mac[i]) {
  81. if(sz(j.S)>1) {
  82. trav(k,j.S) {
  83. tmp[k][i]++;
  84. }
  85. }
  86. }
  87. }
  88. ll cnt=0;
  89.  
  90. rep(i,0,n) {
  91. rep(j,0,n) {
  92. if(tmp[i][j]>1) {
  93. cnt++;
  94. mar[i][v[i][j]].erase(j);
  95. mac[j][v[i][j]].erase(i);
  96. tmp[i][j] = 0;
  97. if(sz(mar[i][v[i][j]])==1) {
  98. tmp[i][*mar[i][v[i][j]].begin()] = 0;
  99. }
  100. if(sz(mac[j][v[i][j]])==1) {
  101. tmp[*mac[j][v[i][j]].begin()][j] = 0;
  102. }
  103. }
  104. }
  105. }
  106.  
  107. rep(i,0,n) {
  108. rep(j,0,n) {
  109. if(tmp[i][j]>0) {
  110. cnt++;
  111. mar[i][v[i][j]].erase(j);
  112. mac[j][v[i][j]].erase(i);
  113. tmp[i][j] = 0;
  114. if(sz(mar[i][v[i][j]])==1) {
  115. tmp[i][*mar[i][v[i][j]].begin()] = 0;
  116. }
  117. if(sz(mac[j][v[i][j]])==1) {
  118. tmp[*mac[j][v[i][j]].begin()][j] = 0;
  119. }
  120. }
  121. }
  122. }
  123.  
  124. cout << cnt << endl;
  125. return;
  126. }
  127. int main()
  128. {
  129. FAST
  130. int TESTS=1;
  131. cin>>TESTS;
  132. rep(i,0,TESTS)
  133. {
  134. // cout<<"Case #"<<i+1<<": ";
  135. solve();
  136. }
  137. TIME
  138. return 0;
  139. }
Advertisement
Add Comment
Please, Sign In to add comment