zoukankan      html  css  js  c++  java
  • 算法

    //****************************************************************************************************
    //
    // 求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 */

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

  • 相关阅读:
    C# 实现 Snowflake算法生成唯一性Id
    kafka可视化客户端工具(Kafka Tool)的基本使用(转)
    docker 安装kafka
    Model类代码生成器
    使用docker 部署rabbitmq 镜像
    Vue 增删改查 demo
    git 提交代码到库
    Android ble蓝牙问题
    mac 配置 ssh 到git (Could not resolve hostname github.com, Failed to connect to github.com port 443 Operation timed out)
    okhttp
  • 原文地址:https://www.cnblogs.com/mfrbuaa/p/4742158.html
Copyright © 2011-2022 走看看