제출 #490768

#제출 시각아이디문제언어결과실행 시간메모리
490768hoangtung_proArranging Shoes (IOI19_shoes)C++14
100 / 100
242 ms274344 KiB
#include<bits/stdc++.h>
 
#define bit(s, i) (s & (1<<i))
#define fi first
#define se second
#define pb push_back
#define endl '\n'
 
using namespace std;
 
const int N = 2e5 + 5;
const int M = 1;
const int K = 1;
const int inf = 2e9;
const long long Inf = 2e18;
const int mod = 1e9 + 7;
 
typedef pair < int, int > ii;
typedef long long ll;
 
int Bit[N], cur[N];
queue < int > pos[N][2];
 
void Update(int i) {
	for(; i < N; i += (i & -i)) Bit[i] ++; 
}
 
int Get(int i) {
	int res = 0;
	for(; i > 0; i -= (i & -i)) res += Bit[i];
	return res;
}
 
long long count_swaps(vector<int> a) {
	int n = a.size() / 2;
	vector < int > solve;
	for(int i=0;i<=2 * n - 1;++i) {
		int x = a[i];
		
		if(x < 0) {
			if(cur[abs(x)] <= 0) solve.pb(abs(x));
			pos[abs(x)][0].push(i + 1);
			cur[abs(x)] --;
			
		}
		else {
			if(cur[abs(x)] >= 0) solve.pb(abs(x));
			pos[abs(x)][1].push(i + 1);
			cur[abs(x)] ++;
		}


	}
	long long res = 0;
	int cnt = 0;
 
	for(int x : solve) {
		int le = pos[x][0].front(), ri = pos[x][1].front();
		pos[x][0].pop(), pos[x][1].pop();
 
		if(le > ri) {
			res ++;
			swap(le, ri);
		}
		//cout << cnt << ' ' << cnt2 << endl;
		res += le + ri;
		res -= 2 * (cnt + 2) - 1;
 
		res -= Get(le) - cnt;
		Update(le), cnt ++;
		res -= Get(ri) - cnt;
		Update(ri), cnt ++;
	}	
 
	return res;
}
 
// int main() {
// 	ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
// 	freopen("trash.inp", "r", stdin);
// 	freopen("trash.out", "w", stdout);
 
// 	int t;
// 	cin >> t;
// 	vector < int > a;
// 	for(int i=1;i<=2*t;++i) {
// 		int x;
// 		cin >> x;
// 		a.pb(x);
// 	}
// 	cout << count_swaps(a);
// }
#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...