算法 - 乞讨n中位数(C++)

本文介绍了一种使用C++快速排序算法来寻找一组数据中位数的方法。通过定义快速排序函数并调用评估中位数函数,可以有效找出奇数或偶数个数据集的中位数。
//****************************************************************************************************
//
// 求n个数的中位数 - C++ - by Chimomo
//
// 对于一组有限个数的数据来说,它们的中位数是这种一种数:这群数据里的一半的数据比它大,而另外一半数据比它小。
// 计算有限个数的数据的中位数的方法是:把全部的同类数据依照大小的顺序排列。

假设数据的个数是奇数,则中间那个数据就是这群数据的中位数;假设数据的个数是偶数,则中间那2个数据的算术平均值就是这群数据的中位数。

// //**************************************************************************************************** #include <iostream> #include <cassert> #include <stack> #include <math.h> using namespace std ; int QuickSortOnce(int a[], int low, int high) { // 将首元素作为枢轴。 int pivot = a[low]; int i = low, j = high; while (i < j) { // 从右到左,寻找首个小于pivot的元素。

while (a[j] >= pivot && i < j) { j--; } // 运行到此,j已指向从右端起首个小于或等于pivot的元素。

// 运行替换。 a[i] = a[j]; // 从左到右。寻找首个大于pivot的元素。 while (a[i] <= pivot && i < j) { i++; } // 运行到此。i已指向从左端起首个大于或等于pivot的元素。 // 运行替换。 a[j] = a[i]; } // 退出while循环,运行至此,必然是i=j的情况。 // i(或j)指向的即是枢轴的位置。定位该趟排序的枢轴并将该位置返回。

a[i] = pivot; return i; } void QuickSort(int a[], int low, int high) { if (low >= high) { return; } int pivot = QuickSortOnce(a, low, high); // 对枢轴的左端进行排序。 QuickSort(a, low, pivot - 1); // 对枢轴的右端进行排序。 QuickSort(a, pivot + 1, high); } int EvaluateMedian(int a[], int n) { QuickSort(a, 0, n - 1); if(n % 2 !=0) { return a[n / 2]; } else { return (a[n / 2] + a[n / 2 - 1]) / 2; } } int main() { int a[9] = {-5, 345, 88, 203, 554, 1, 89, 909, 1001}; cout << EvaluateMedian(a, 9) << endl; return 0; } // Output: /* 203 */

版权声明:本文博客原创文章,博客,未经同意,不得转载。






本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4742158.html,如需转载请自行联系原作者


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值