求逆序对

还记得在思科实习的时候能轻松写出来,现在写得就不轻松了,一个很粗糙的代码:

#include <iostream>
#include <vector>

using namespace std;

int array[] = {3, 9, 7, 4, 5, 2};
const int size = sizeof array / sizeof *array;
int temp[size];
//int numbers[size];

int reversePair(int *numbers, int start, int last, int &index, int &count)
{
	if(start == last)
		return 0;

	int mid = (last - start) / 2 + start;
	reversePair(numbers, start, mid, index, count);
	reversePair(numbers, mid + 1, last, index, count);

	for(int i = start; i <= last; i++)
		temp[i] = numbers[i];

	int index1 = start, index2 = mid + 1;
	index = start;
	while(index1 <= mid && index2 <= last) {
		if(temp[index1] > temp[index2]) {
			numbers[index] = temp[index2];
			count += mid - index1 + 1;
			index++;
			index2++;
		} else if(temp[index1] == temp[index2]) {
			numbers[index] = temp[index1];
			index++;
			index1++;
			index2++;
		} else if(temp[index1] < temp[index2]) {
			numbers[index] = temp[index1];
			index++;
			index1++;
		}
	}

	if(index1 <= mid) {
		while(index1 <= mid) {
			numbers[index] = temp[index1];
			index++;
			index1++;
		}
	} else {
		while(index2 <= last) {
			numbers[index] = temp[index2];
			index++;
			index2++;
		}
	}

	return count;
}

void main()
{
	int count = 0;
	int index = 0;
	reversePair(array, 0, size - 1, index, count);

	cout << "count = " << count << endl;
}


结果为 10.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值