三个数组求中位数,并且求最后中位数的中位数-----C++算法实现
文件Median.h
#include <list>
class CMedian
{
public:
explicit CMedian();
virtual ~CMedian();
void getMedian(float& NumberOfMedian); std::list<float> array;
};
文件Median.cpp
#include "Median.h" CMedian::CMedian()
{
} CMedian::~CMedian()
{
} void CMedian::getMedian(float& NumberOfMedian)
{
array.sort();
int n = array.size();
std::list<float>::iterator itr = array.begin();
for(int i = 0;i < n/2; ++i)
itr++;
if(0 == n % 2)
{
NumberOfMedian = (*itr + *(--itr)) / 2;
}
else
{
NumberOfMedian = *itr;
}
}
文件:main.cpp
#include "Median.h"
#include <vector>
#include <iostream> int _tmain(int argc, _TCHAR* argv[])
{
float a[4] = {3,1,9,5};
float b[4] = {8,-1,6,3};
float c[4] = {1,2,4,0};
CMedian *array1 = new CMedian();
CMedian *array2 = new CMedian();
CMedian *array3 = new CMedian();
CMedian *sumArray = new CMedian();
for(int i = 0; i < 4;i++)
{
array1->array.push_back(a[i]);
}
for(int i = 0; i < 4;i++)
{
array2->array.push_back(b[i]);
}
for(int i = 0; i < 4;i++)
{
array3->array.push_back(c[i]);
} float NumberOfMedian1 = 0;
float NumberOfMedian2 = 0;
float NumberOfMedian3 = 0;
array1->getMedian(NumberOfMedian1);
array2->getMedian(NumberOfMedian2);
array3->getMedian(NumberOfMedian3); std::cout<<NumberOfMedian1<<std::endl;
std::cout<<NumberOfMedian2<<std::endl;
std::cout<<NumberOfMedian3<<std::endl; sumArray->array.push_back(NumberOfMedian1);
sumArray->array.push_back(NumberOfMedian2);
sumArray->array.push_back(NumberOfMedian3); float finalMedian = 0;
sumArray->getMedian(finalMedian);
std::cout<<finalMedian<<std::endl;
std::cin>>finalMedian;
return 0;
}
实际图

三个数组求中位数,并且求最后中位数的中位数-----C++算法实现的更多相关文章
- 三个数组求中位数,以及中位数的中位数----java算法实现
求三个数组的中位数,以及中位数的中位数. import java.util.Arrays; public class median { public static void main(String ...
- 使用基础知识完成java小作业?强化练习-1.输入数组计算最大值-2.输出数组反向打印-3.求数组平均值与总和-4.键盘输两int,并求总和-5.键盘输三个int,并求最值;
完成几个小代码练习?让自己更加强大?学习新知识回顾一下基础? 1.输入数组计算最大值 2.输出数组反向打印 3.求数组平均值与总和 4.键盘输两int,并求总和 5.键盘输三个int,并求最值 /* ...
- PAT 基础编程题 4-11 求自定类型元素序列的中位数(希尔排序)
4-11 求自定类型元素序列的中位数 (25分) 本题要求实现一个函数,求N个集合元素A[]的中位数,即序列中第\lfloor N/2 +1\rfloor⌊N/2+1⌋大的元素.其中集合元素的类型 ...
- 树状数组 && 线段树应用 -- 求逆序数
参考:算法学习(二)——树状数组求逆序数 .线段树或树状数组求逆序数(附例题) 应用树状数组 || 线段树求逆序数是一种很巧妙的技巧,这个技巧的关键在于如何把原来单纯的求区间和操作转换为 求小于等于a ...
- 关于数组array_diff(array1, array2)求差集来比较数组是否相等的问题细究
无意中发现很多朋友都喜欢使用array_diff(array1, array2)来判断两个数组是否相等, 我自己也偶尔会这么使用 但是今天我在写代码的过程中无意发现这么做是不准确的. 首先我们来看一下 ...
- 058 01 Android 零基础入门 01 Java基础语法 06 Java一维数组 05 案例:求数组元素的最大值
058 01 Android 零基础入门 01 Java基础语法 06 Java一维数组 05 案例:求数组元素的最大值 本文知识点:求数组元素的最大值 案例:求数组元素的最大值 程序代码及其执行过程 ...
- 057 01 Android 零基础入门 01 Java基础语法 06 Java一维数组 04 案例:求整型数组的数组元素的元素值累加和
057 01 Android 零基础入门 01 Java基础语法 06 Java一维数组 04 案例:求整型数组的数组元素的元素值累加和 本文知识点:求整型数组的数组元素的元素值累加和 案例:求整型数 ...
- 求余VS求模--C语言中表述
之前看帖子,发现许多时候基本上大家都把求模和求余混为一谈了.但实际上二者的概念是有区别的 1. 求余 在C语言中,求余对应的操作符是%,且a%b求余的最后结果总是与a符号相同,最后的数值为|a|% ...
- Numpy学习三:数组运算
1.转置 #reshape(shape)函数改变数组形状,shape是一个元组,表示数组的形状 创建一个包含15个元素的一维数组,通过reshape函数调整数组形状为3行5列的二维数组arr = np ...
- php实现用短路求值原理求1+2+3+...+n(短路求值是什么)(仔细分析题干)
php实现用短路求值原理求1+2+3+...+n(短路求值是什么)(仔细分析题干) 一.总结 1.仔细分析题干,找出要点:该递归还是得递归啊 2.短路求值原理:&&就是逻辑与,逻辑与有 ...
随机推荐
- if __name__ == '__main__'的作用和原理
最简单的理解就是这样: __name__ 是当前模块名,当模块被直接运行时,模块名为 __main__. 所以 if __name__ == '__main__' 这句话的意思就是当前模块被直接运行时 ...
- default of c#
[default of c#] 在泛型类和泛型方法中产生的一个问题是,在预先未知以下情况时,如何将默认值分配给参数化类型 T: T 是引用类型还是值类型. 如果 T 为值类型,则它是数值还是结构. 给 ...
- 10 华电内部文档搜索系统 search03
上一节讲解了怎么在Struts 2下面使用内置对象传值,在Struts 2下面是用Session或者Request存放对象.在Struts 2下面是用内部对象传值,和JSP页面下面稍微有些不同.但是实 ...
- 一道面试题Lintcode196-Find the Missing Number
http://www.lintcode.com/en/problem/find-the-missing-number/# Find the Missing Number Given an array ...
- 81-POJ-Wall(计算几何)
http://poj.org/problem?id=1113 Wall Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 411 ...
- [C++] const and char*
const and char* NOTICE: char *str = "hello"; the value of str is the address of the fi ...
- 使用python进行汉语分词-乾颐堂
目前我常常使用的分词有结巴分词.NLPIR分词等等 最近是在使用结巴分词,稍微做一下推荐,还是蛮好用的. 一.结巴分词简介 利用结巴分词进行中文分词,基本实现原理有三: 基于Trie树结构实现高效的词 ...
- 修改ubuntu密码
https://www.linuxidc.com/Linux/2016-05/131256.htm
- combotree 满足条件的节点不可选中
combotree: $("#Parent").treegrid("unselect");
- [C#] IEnumerable vs IQueryable
这篇博客将介绍IEnumerable和IQueryable之间的区别. 1. IQueryable是继承自IEnumerable接口的.所以IEnumerable能做的,IQueryable都能做. ...