summaryrefslogtreecommitdiff
path: root/math/inversions.cpp
blob: 02256cae4a77cca4f35e110de6401901f285b82e (plain)
1
2
3
4
5
6
7
8
9
ll inversions(const vector<ll>& v) {
	Tree<pair<ll, ll>> t; //ordered statistics tree
	ll res = 0;
	for (ll i = 0; i < (ll)v.size(); i++) {
		res += i - t.order_of_key({v[i], i});
		t.insert({v[i], i});
	}
	return res;
}