제출 #493612

#제출 시각아이디문제언어결과실행 시간메모리
493612protonArranging Shoes (IOI19_shoes)C++17
100 / 100
156 ms139376 KiB
#include <bits/stdc++.h> using namespace std; struct Segtree { int n; vector<int> t; Segtree(int n) { this -> n = n; t.resize(n << 1); } inline int op(int a, int b) { return a + b; } int range_sum(int l, int r) { int res = 0; for(l += n, r += n; l < r; l >>= 1, r >>= 1) { if(l & 1) res = op(res, t[l++]); if(r & 1) res = op(res, t[--r]); } return res; } void modify(int p) { for(t[p += n] = 1; p > 1; p >>= 1) t[p >> 1] = op(t[p], t[p^1]); } }; // inversions in a permutation p[1 .. n] long long inversions(int p[], int n) { Segtree st(n); long long res = 0; for(int i = 0; i < n; i++) { st.modify(p[i] - 1); res += st.range_sum(p[i], n); } return res; } long long count_swaps(vector<int> a) { int n = (int) a.size(); int p[n], m = n / 2; queue<int> mp[n + 2]; for(int i = 0, c = 1; i < n; i++) { if(mp[m + a[i]].empty()) { if(a[i] > 0) { mp[m - a[i]].push(c); p[i] = c + 1; } else { p[i] = c; mp[m - a[i]].push(c + 1); } c += 2; } else { p[i] = mp[m + a[i]].front(); mp[m + a[i]].pop(); } } return inversions(p, n); } // int main() // { // int n; cin >> n; // vector<int> v(n + n); // for(int &x: v) cin >> x; // cout << count_swaps(v); // }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...