Submission #1135149

#TimeUsernameProblemLanguageResultExecution timeMemory
1135149RaduMXor Sort (eJOI20_xorsort)C++20
Compilation error
0 ms0 KiB
#include <bits/stdc++.h> using namespace std; int v[1005]; map <int, int> mp; vector < pair <int, int> > sol; void divide(int st, int dr){ if(st == dr) return; int b2 = -1, p = 0; for(int i = st; i <= dr; i++){ if(31 - __builtin_clz(v[i]) > b2){ b2 = 31 - __builtin_clz(v[i]); p = i; } } if(b2 < 0) return; for(int i = p; i < dr; i++){ if((1 << b2) & v[i + 1]){ sol.push_back({i, i + 1}); v[i] ^= v[i + 1]; } else{ sol.push_back({i + 1, i}); v[i + 1] ^= v[i]; sol.push_back({i, i + 1}); v[i] ^= v[i + 1]; } } divide(st, dr - 1); } int main() { int n,i,c,k; ios_base::sync_with_stdio(false); cin.tie(nullptr); cin >> n >> c; for(i = 1; i <= n; i++) cin >> v[i]; if(c == 1){ k = 0; for(i = 1; i <= n; i++) mp[v[i]] = 1; for(auto &x : mp) x.second = ++k; for(i = 1; i <= n; i++) v[i] = mp[v[i]]; for(i = 1; i < n; i++) sol.push_back({i, i + 1}); for(i = n; i >= 2; i--){ int p = 0; for(p = 1; p < i; p++){ if(v[p] == i) break; } for(int j = p; j < i; j++){ sol.push_back({j + 1, j}); swap(v[j], v[j + 1]); } for(int j = max(1, p - 1); j < i; j++) sol.push_back({j, j + 1}); } cout << (int)sol.size() << "\n"; for(auto x : sol) cout << x.first << " " << x.second << "\n"; return 0; } divide(1, n); cout << (int)sol.size() << "\n"; for(auto x : sol) cout << x.first << " " << x.second << "\n";= return 0; }

Compilation message (stderr)

xorsort.cpp: In function 'int main()':
xorsort.cpp:64:66: error: expected primary-expression before '=' token
   64 |     for(auto x : sol) cout << x.first << " " << x.second << "\n";=
      |                                                                  ^
xorsort.cpp:65:5: error: expected primary-expression before 'return'
   65 |     return 0;
      |     ^~~~~~