三个数组求中位数,并且求最后中位数的中位数-----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.短路求值原理:&&就是逻辑与,逻辑与有 ...
随机推荐
- JS中如何获取当前时间及让时间格式化
JS中获取当前时间和JAVA里获取当前时间一样,都是直接new Date即可.不同的是,JS中用var date=new Date();JAVA中用Data data=new Date();注:JS中 ...
- Cookie&Session会话跟踪技术
今日内容学习目标 可以响应给浏览器Cookie信息[response.addCookie()] 可以接受浏览器Cookie信息[request.getCookies()] [创建cookie,设置pa ...
- centos7 时间修改
转子 http://blog.csdn.net/kuluzs/article/details/52825331 在CentOS 6版本,时间设置有date.hwclock命令,从CentOS 7开始, ...
- centos7 yum 安装 mysql
CentOS7默认数据库是mariadb,配置等用着不习惯,因此决定改成mysql,但是CentOS7的yum源中默认好像是没有mysql的.为了解决这个问题,我们要先下载mysql的repo源. 1 ...
- linux:alias
linux系统下常用一个“命令”ll,它实质上是一个别名,而非命令. 我们用它的前提是,在~/.bashrc文件里打开,默认有条记录: #alias ll=’ls -l’ 这就是别名的格式.把注释去掉 ...
- C++ std::unordered_multiset
std::unordered_multiset template < class Key, // unordered_multiset::key_type/value_type class Ha ...
- ROS tf 编程指南
ROS (Robot Operating System, 机器人操作系统)是最知名的机器人操作系统,广泛应用于无人驾驶和机器人,tf(transforms,坐标系转换)是ROS下的一个常用的工具库.r ...
- archives of source
"ubuntu 暂时不能解析域名 archive.ubuntu.com"怎么办? root下输入命令:lsb_release -a用来查询Ubuntu版本号 登录网站 http:/ ...
- Android中Cursor类的概念和用法[转]
首页 > 程序开发 > 移动开发 > Android > 正文 Android中Cursor类的概念和用法 2011-09-07 0个评论 收藏 ...
- Python爬虫实战二之爬取百度贴吧帖子
大家好,上次我们实验了爬取了糗事百科的段子,那么这次我们来尝试一下爬取百度贴吧的帖子.与上一篇不同的是,这次我们需要用到文件的相关操作. 前言 亲爱的们,教程比较旧了,百度贴吧页面可能改版,可能代码不 ...