Advertisement
skimono

Untitled

Feb 23rd, 2023
643
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.86 KB | None | 0 0
  1.  
  2. // clang-format off
  3. #define _CRT_SECURE_NO_WARNINGS
  4.  
  5. #include <iostream>
  6. #include <vector>
  7. #include <string>
  8. #include <algorithm>
  9. #include <cmath>
  10. #include <stack>
  11. #include <iomanip>
  12. #include <fstream>
  13. #include <string>
  14. #include <set>
  15. #include <deque>
  16. #include <queue>
  17. #include <map>
  18. #include <bitset>
  19. #include <random>
  20. #include <list>
  21. #include <unordered_map>
  22. #include <unordered_set>
  23. #include <cassert>
  24.  
  25. using namespace std;
  26.  
  27. typedef long long ll;
  28. typedef unsigned long long ull;
  29. typedef long double ld;
  30. typedef string str;
  31. //typedef __int128 ultraint;
  32. #define sqrt sqrtl
  33. #define F first
  34. #define S second
  35. #define endl '\n'
  36. #define all(vc666) vc666.begin(), vc666.end()
  37. #define allr(vc666) vc666.rbegin(), vc666.rend()
  38. #define int long long
  39. #define degug(x) cerr (#x) << " " << (x) << endl;
  40.  
  41. const ll INF = (ll)1e18;
  42. const ll inf = 1e9 + 7;
  43. const ll ONE = 1;
  44. const ll mod = 998244353;
  45. const ll LG = 20;
  46. ld EPS = 1e-12;
  47. ld PI = 3.1415926535897932384;
  48. mt19937_64 gen(rand() + rand());
  49.  
  50. void solve() {
  51.     int n, m, i, j, k, hsh = 0, B = 10;
  52.     cin >> n >> m;
  53.     unordered_map <int, vector <int> > zxc(2 * n * m);
  54.     vector <vector <int> > a(n, vector <int>(m));
  55.     vector <vector <int> > b;
  56.     unordered_map <int, vector <int> > cursed(2 * n * m);
  57.     unordered_set <int> zxc2(2 * n * m);
  58.     for (i = 0; i < n; i++) {
  59.         hsh = 0;
  60.         for (j = 0; j < m; j++) {
  61.             cin >> a[i][j];
  62.             hsh = hsh * B + a[i][j];
  63.         }
  64.         cursed[hsh].push_back(i);
  65.         if (zxc2.find(hsh) != zxc2.end()) continue;
  66.         zxc2.insert(hsh);
  67.         b.push_back(a[i]);
  68.     }
  69.     for (i = 0; i < b.size(); i++) {
  70.         hsh = 0;
  71.         for (j = 0; j < m; j++) {
  72.             hsh = hsh * B + b[i][j];
  73.             zxc[hsh].push_back(i);
  74.         }
  75.     }
  76.     vector <int> ans(n, 0), ans2(b.size(), 0);
  77.     for (i = 0; i < b.size(); i++) {
  78.         hsh = 0;
  79.         for (k = 1; k <= m; k++) {
  80.             j = find(all(b[i]), k) - b[i].begin() + 1;
  81.             hsh = hsh * B + j;
  82.             if (zxc.find(hsh) != zxc.end()) {
  83.                 for (auto it : zxc[hsh]) {
  84.                     ans2[it] = max(ans2[it], k);
  85.                 }
  86.             }
  87.             else {
  88.                 break;
  89.             }
  90.         }
  91.     }
  92.     for (i = 0; i < b.size(); i++) {
  93.         hsh = 0;
  94.         for (j = 0; j < m; j++) {
  95.             hsh = hsh * B + b[i][j];
  96.         }
  97.         for (auto it : cursed[hsh]) {
  98.             ans[it] = ans2[i];
  99.         }
  100.     }
  101.     for (i = 0; i < n; i++) {
  102.         cout << ans[i] << " ";
  103.     }
  104.     cout << endl;
  105. }
  106.  
  107. signed main() {
  108. #ifdef _DEBUG
  109.     freopen("input.txt", "r", stdin);
  110.     freopen("output.txt", "w", stdout);
  111. #endif
  112.     ios_base::sync_with_stdio(0);
  113.     cin.tie(NULL);
  114.     cout.tie(NULL);
  115.     int t = 1;
  116.     cin >> t;
  117.     while (t--) solve();
  118. }
  119. //Deisgned by skimono
  120.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement