三个数组求中位数,并且求最后中位数的中位数-----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.短路求值原理:&&就是逻辑与,逻辑与有 ...
随机推荐
- linux 常用查看设备命令(转)
# uname -a # 查看内核/操作系统/CPU信息 # /etc/issue # 查看操作系统版本 # cat /proc/cpuinfo # 查看CPU信息 # hostname # 查看计算 ...
- e s6 知识点
http://es6.ruanyifeng.com/#docs/reflect 1.资料对es6箭头函数中的this总结:箭头函数中的this指向的是 定义时的this,而不是 执行时的this.
- Scanner和BufferReader之区别
在Java SE6中我们可知道一个非常方便的输入数据的类Scanner,位于java.util包中,这个Scanner的具体用法为Scanner in = new Scanner(System.in) ...
- easyui datagrid combobox下拉框获取数据问题
最近在使用easyui的datagrid,在可编辑表格中添加一个下拉框,查了下API,可以设置type : 'combobox',来做下拉框,这下拉框是有了,可是这后台数据怎么传过来呢,通过查API可 ...
- Request.IsAuthenticated
Original question that the answer below refers to: I have a forms based application that is giving m ...
- Spring中Aspect的切入点的表达式定义细节
用过很多次切面aspect了,对于表达式总是记得很模糊,今天总结一下. 1.切面做如下设置则只会拦截返回值为String类型的方法 @Aspect public class MyInterceptor ...
- Spring学习笔记(三)--Convert System设计
一.概述 转换系统是不同范式系统间交互常常会需要碰到的,如WEB 中HTTP KV文本流到对象的转换和对象到http KV文本流的转换:还有对象到关系型DB和关系型DB到对象之间的转换(ORM). 一 ...
- vmware Selinux配置错误,导致无法启动虚拟机
Linux 开机提示kernel panic - not syncing: Attempted to kill init! 解决方法: 系统启动的时候,按下‘e’键进入grub编辑界面,编辑grub菜 ...
- SQL 数据库 学习 005 学习必备的一些操作 --- 如何新建数据库 如何附加和分离数据库(如何备份还原数据库) 如何删除数据库
我的电脑系统: Windows 10 64位 使用的SQL Server软件: SQL Server 2014 Express 如果我们要学习这个数据库,我们需要学习什么知识.比如:如何新建一个数据库 ...
- 最近工作的一点小tips
最近工作比较忙,但也积累了一些小tips,比较杂,不成系统,也并不很深入,就开一篇笼统的先记录一下,以后再深入挖掘. 1.-webkit-tap-highlight-color -webkit-tap ...