博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法 - 乞讨n中位数(C++)
阅读量:6684 次
发布时间:2019-06-25

本文共 1551 字,大约阅读时间需要 5 分钟。

//****************************************************************************************************//// 求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,如需转载请自行联系原作者

你可能感兴趣的文章
iptables实现NAT(网络搜索整理)
查看>>
关于ip地址
查看>>
ASP.NET自定义404和500错误页面
查看>>
OpenGL学习(七)纹理映射
查看>>
一些必不可少的Sublime Text 2插件
查看>>
<進階&高級>ADT線上視頻&PPT課件
查看>>
iOS md5加密
查看>>
测试项目
查看>>
第一章ASP.NET SignalR简介
查看>>
SSH
查看>>
使用python3来生成安全的随机密码
查看>>
41-50(UIApplication和delegate,UIApplicationMain,UIWindow,程序启动的完整过程,控制器view的延迟加载)...
查看>>
HTTP服务器实现
查看>>
2017.03
查看>>
95Cloud 可信云计算管理系统(IaaS) ———持续数据保护(CDP)简介
查看>>
锁等待分析处理
查看>>
未能加载文件或程序集“System.Data.SQLite”或它的某一个依赖项
查看>>
傻瓜式操作Nagios
查看>>
Spring task配置,及解决加载两次的方法
查看>>
仿淘宝套餐选择插件 基于jQuery(原创)
查看>>