求逆序对

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

#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;
}

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
9757次浏览 91人参与
# 你的实习产出是真实的还是包装的? #
1758次浏览 40人参与
# MiniMax求职进展汇总 #
23866次浏览 308人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7480次浏览 43人参与
# 简历第一个项目做什么 #
31574次浏览 331人参与
# 重来一次,我还会选择这个专业吗 #
433386次浏览 3926人参与
# 米连集团26产品管培生项目 #
5767次浏览 214人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187010次浏览 1122人参与
# 牛客AI文生图 #
21410次浏览 238人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152302次浏览 887人参与
# 研究所笔面经互助 #
118874次浏览 577人参与
# 简历中的项目经历要怎么写? #
310086次浏览 4195人参与
# AI时代,哪些岗位最容易被淘汰 #
63454次浏览 805人参与
# 面试紧张时你会有什么表现? #
30490次浏览 188人参与
# 你今年的平均薪资是多少? #
213021次浏览 1039人参与
# 你怎么看待AI面试 #
179885次浏览 1235人参与
# 高学历就一定能找到好工作吗? #
64316次浏览 620人参与
# 你最满意的offer薪资是哪家公司? #
76442次浏览 374人参与
# 我的求职精神状态 #
447997次浏览 3129人参与
# 正在春招的你,也参与了去年秋招吗? #
363256次浏览 2637人参与
# 腾讯音乐求职进展汇总 #
160590次浏览 1111人参与
# 校招笔试 #
470514次浏览 2964人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务