본문 바로가기

Algorithm/Tree

MEASURETIME (FENWICK TREE)

#include 
#include 

using namespace std;

struct FenwickTree {
	vector tree;
	FenwickTree(int n) : tree(n + 1) {}

	int sum(int pos) {
		++pos;
		int ret = 0;
		while (pos > 0) {
			ret += tree[pos];
			pos &= (pos - 1);
		}

		return ret;
	}

	void add(int pos, int val) {
		++pos;
		while (pos < tree.size()) {
			tree[pos] += val;
			pos += (pos & -pos);
		}
	}
};


long long countMoves(vector &arr);

int main()
{
	int cn = 0;
	cin >> cn;

	int n = 0;
	for (int ci = 0; ci < cn; ci++)
	{
		cin >> n;
		vector arr = vector(n);
		for (int i = 0; i < n; i++)
			cin >> arr[i];

		cout << countMoves(arr) << endl;
	}
}

long long countMoves(vector &arr)
{
	FenwickTree tree = FenwickTree(1000000);
	long long ret = 0;

	for (int i = 0; i < arr.size(); i++)
	{
		ret += tree.sum(999999) - tree.sum(arr[i]);
		tree.add(arr[i], 1);
	}

	return ret;
}

MeasuretimeInput.txt
0.00MB

 

MeasuretimeOutput.txt
0.00MB

 

 

 

반응형

'Algorithm > Tree' 카테고리의 다른 글

EDITOR WARS  (0) 2019.11.02
MORDOR  (0) 2019.10.29
RUNNINGMEDIAN  (0) 2019.10.26
TREAP_INSERTION  (0) 2019.10.26
FORTRESS  (0) 2019.10.25