求逆序对

查了好久没正确 神奇的求逆序对

#include<iostream>
#include<algorithm>
using namespace std;

typedef long long LL;
LL cnt = 0;//逆序数计数

void Merge(int* ar, int l, int mid, int r, int* tmp) {
	int i = l, j = mid + 1;
	int k = 0;

	while (i <= mid && j <= r) {
		if (ar[i] < ar[j]) {
			tmp[k++] = ar[i++];
		}
		else {
			tmp[k++] = ar[j++];
			cnt += mid - i + 1;//比归并排序多的一步
		}
	}
	while (i <= mid)
		tmp[k++] = ar[i++];
	while (j <= mid)
		tmp[k++] = ar[i++];
	for (int i = 0; i < k; ++i)
		ar[l + i] = tmp[i];
}

void solve(int* ar, int l, int r, int* tmp) {
	if (l < r) {
		int mid = l + (r - l) / 2;
		solve(ar, l, mid, tmp);
		solve(ar, mid + 1, r, tmp);
		Merge(ar, l, mid, r, tmp);
	}
}

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

	int* ar = new int[n];
	int* tmp = new int[n];

	for (int i = 0; i < n; ++i)
		cin >> ar[i];

	solve(ar, 0, n - 1, tmp);

	cout << cnt;

	delete[] ar;
	delete[] tmp;
	return 0;
}

全部评论

相关推荐

李橙子:结果虽不够理想,但过程本身已是宝贵的淬炼。能把学习机会放在薪酬之前,证明你目光长远。先踏实进去,用这段时间扎实学好Python后端,把公司项目吃透,你的价值会在下一份工作中完全体现。这个起点,值得。
点赞 评论 收藏
分享
king327:要从现有项目中挖掘1-2个你解决过的具体技术难题 详细描述你的解决方案、技术选型理由和最终效果 这比罗列更多基础功能更有说服力
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务