两个序列的中位数c语言,小白在线求教 用归并排序实现查找两个有序序列的中位数...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

两个有序序列的中位数 (20分)

已知有两个等长的非降序序列S1, S2, 设计函数求S1与S2并集的中位数。有序序列A0,A1,⋯,AN−1的中位数指A(N−1)/2的值,即第⌊(N+1)/2⌋个数(A0为第1个数)。

输入格式:

输入分三行。第一行给出序列的公共长度N(0

输出格式:

在一行中输出两个输入序列的并集序列的中位数。

输入样例1:51 3 5 7 92 3 4 5 6输出样例1:4输入样例2:6-100 -10 1 1 1 1-50 0 2 3 4 5输出样例2:1

本人所写代码:不知如何修改😭

#include "stdio.h"

#include "stdlib.h"

#define N 100000

using namespace std;

void Merge(int r1[N],int low,int mid,int high,int r2[N])

{ //合并两个序列

int i=low;//第一个序列的第一个元素

int j=mid+1;//第二个序列的第一个元素

int k=low;//合并后新序列的第一个元素

while((i<=mid)&&(j<=high))

{//两序列进行合并时元素均未取完

if(r1[i]<=r1[j])//序列1的元素小于序列2的 ,则将序列1的元素放入新序列中

r2[k++]=r1[i++];

else//反之,将序列2的元素放入新序列中

r2[k++]=r1[j++];

}

while(i<=mid)//若序列2的元素全放入新序列,而序列1的元素未放完,则将序列1剩余元素放入新序列

{r2[k++]=r1[i++];}

while(i<=mid)//若序列1的元素全放入新序列,而序列2的元素未放完,则将序列2剩余元素放入新序列

{r2[k++]=r1[j++];}

}

void MSort(int r1[N],int low,int high,int r3[N])

{//归并排序

int mid;

int *r2;

r2=(int *)malloc(sizeof(int)*(high-low+1));//辅助数组空间

if(low==high)//序列元素刚好都放入

r3[low]=r1[low];

else

{

mid=(low+high)/2;//找中间点

MSort(r1,low,mid,r2);//递归划分左半区

MSort(r1,mid+1,high,r2);//递归划分右半区

Merge(r2,low,mid,high,r3);//合并已经排好的部分

}

free(r2);

}

void MergeSort(int r[],int n)//归并排序入口

{

int high,low;

int *r2;

r2=(int *)malloc(sizeof(int)*(high-low+1));//辅助空间

MSort (r,0,n-1,r2);

free(r2);

}

int main(){

int a[N],b[N],c[N],d[N],e[N];

int n,i,j;

scanf("%d",&n);

for (i=0;i

scanf("%d",&a[i]);

for (j=0;j

scanf("%d",&b[j]);

MergeSort(a,n);

MergeSort(b,n);

for(i=0;i<2*n;i++)

printf("%d ",a[i]);

//printf("%d\n",c[(2*n-1)/2]);

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/506517.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

c语言优化冒泡法,C语言:冒泡法排序一组数,如何优化?

#define _CRT_SECURE_NO_WARNINGS 1#include#includeint main(){int arr[] { 5, 6, 7, 8, 9 ,1, 2, 3, 4};int i 0;int j 0;int flag;int size sizeof(arr) / sizeof(arr[0]);for (i 0; i < size- 1 ; i){flag 1;//设置标志位&#xff0c;优化冒泡for (j 0; j < s…

android-短信验证功能,Android实现获取短信验证码的功能以及自定义GUI短信验证详解...

《Android实现获取短信验证码的功能以及自定义GUI短信验证详解》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《Android实现获取短信验证码的功能以及自定义GUI短信验证详解(8页珍藏版)》请在人人文库网上搜索。1、Android实现获取短信验证码的功能以 及自定义GUI短信…

android 分享到豆瓣,Android项目总结之社会化分享

随着现在社交网络的日益繁多&#xff0c;众多的社交客户端已占据了人们的大量时间&#xff0c;所以在我们的应用中具有一键分享的功能对提高我们产品的知名度有很大的帮助。新浪微博、腾讯微博、腾讯QQ、微信、QQ空间、豆瓣等众多知名社交站点&#xff0c;都是我们可以分享的去…

android实现自动横竖屏切换,android 中实现横竖屏切换【原创】

我们在使用android手机的时候&#xff0c;发现一些应用有横竖屏切换的功能&#xff0c;一般实现有以下几种方法&#xff1a;一、设置1.通过XML设置横竖屏切换在项目的 AndroidManifest.xml中找到你所指定的activity中加上android:screenOrientation属性&#xff0c;它有以下几个…

超级管理器Android,超级文件管理器app

详情超级文件管理器app&#xff0c;一款帮助你管理手机内存的软件&#xff0c;还可以重命名&#xff0c;移动&#xff0c;删除文件&#xff0c;在Android平台上完美运行&#xff0c;并能够与其他OI系列软件结合使用! 能快速地查找到目标文件&#xff0c;十分方便用户管理自己手…

android miui ios,从iOS到Android——小米11及小米生态实际使用体验

从iOS到Android——小米11及小米生态实际使用体验2021-02-22 15:29:5693点赞155收藏131评论创作立场声明&#xff1a;文中的设备均为自购&#xff0c;无任何特定立场。2021年2月10日&#xff0c;我的iPhoneX手机突然黑屏&#xff0c;拿到Apple Store检测&#xff0c;经诊断是屏…

android amd cpu架构,AMD CPU 架构

同频率、同缓存容量的CPU才能比较出不同架构的优劣。目前Intel、AMD常见CPU架构性能从高到低&#xff1a;Intel Core i7 (Core i7/ Core i5)AMD K10.5 (PhenomII)Intel Core/Core2AMD K10 (Phenom)AMD K8AMD K7Intel P6 (PentiumM、Pentium3、Pentium2、PentiumPro)Intel NetBu…

p50会搭载鸿蒙吗,华为Mate40和华为P50也会搭载鸿蒙,华为Mate30跌至白菜价让路

原标题&#xff1a;华为Mate40和华为P50也会搭载鸿蒙&#xff0c;华为Mate30跌至白菜价让路华为Mate40和华为P50也会搭载鸿蒙&#xff0c;华为Mate30跌至白菜价让路&#xff01;华为P50Pro的机身部分后置摄像头模块的外观有发生了改变&#xff0c;可以看到华为P50Pro并没有将所…

android 天气接口简书,天气API接口说明

天气API接口稳定的确实没有&#xff0c;除非是天气官方提供的&#xff0c; 但是我观察了下&#xff0c;要是合作伙伴才有开放的可能。其他的&#xff0c;例如&#xff1a;百度 APIStore、一些同学在其他网站上抓包下来的接口&#xff0c;以及什么各种收费的 API&#xff0c;都没…

html中如何在标题中加样式,html title属性 样式

css 中title属性怎样设置文本样式&#xff1f;如加颜色、设置打开开发工具&#xff0c;新建一个HTML文件。使用font-family属性设置&#xff0c;字体代码&#xff1a;.demo1{font-family: "microsoft yahei";}。使用font-size属性设置字体的大小代码&#xff1a;.dem…

计算机科学计算第二版第四章,大连理工大学 计算机科学计算 第四章2.pdf

大连理工大学 计算机科学计算 第四章2第4章 插值与逼近4.2.4 Hermite插 值4.2.4 Hermite插值理论和应用中提出的某些插值问题&#xff0c;要求插值函数p (x)具有一定的光滑度&#xff0c;即在插值节点处满足一定的导数条件&#xff0c;这类插值问题称为Hermite插值问题。 Hermi…

html如何算小于0判断错误,如果长度小于0在javascript中提醒

如果当前长度为0个字符...我想提醒没有剩下的字符&#xff01;10$(document).ready(function(){//alert("test!!");var combined_text_length 0;var limit 10;$("input.text_question_1").live(keyup, function (e){current_length 0;$.each($("in…

图像识别利用计算机对图像进行,图像识别方法

图像识别&#xff0c;是指利用计算机对图像进行处理、分析和理解&#xff0c;以识别各种不同模式的目标和对像的技术。图像识别是人工智能的一个重要领域。主要的图像识别方法有基于神经网络的图像识别方法、基于小波矩的图像识别方法等。中文名图像识别方法外文名image recogn…

linux将db2账户添加到组_超实用的shell脚本--Linux安全加固设置,值得收藏

概述近几年来Internet变得更加不安全了。网络的通信量日益加大&#xff0c;越来越多的重要交易正在通过网络完成&#xff0c;与此同时数据被损坏、截取和修改的风险也在增加。 只要有值得偷窃的东西就会有想办法窃取它的人。Internet的今天比过去任何时候都更真实地体现出这一点…

微型计算机指令系统例题,微机原理复习题(指令系统)

微机原理复习题(指令系统)《微机原理》复习题二一、选择题1、假设外部设备的状态字已经读入AL寄存器,其中最低位为"0",表示外部设备"忙", 为了判断外部设备是否"忙"而又不破坏其它状态位,应选用下列( )组指令。A. RCR AL, 01H JZ Label B. CMP A…

迷你世界无人驾驶地铁火车_出口伊斯坦布尔地铁列车“云下线”

轨道世界 RailWorld开放&#xff5c;共享&#xff5c;价值导读 ID&#xff1a;RailWorld出口伊斯坦布尔地铁列车“云下线”全自动无人驾驶&#xff0c;全寿命远程跟踪、诊断和维护&#xff0c;全车内循环感应系统&#xff0c;极具土耳其风情的外观及内饰……7月14日&#xff0c…

易安卓 html5,Developing a Multi Platforms Web Applications for Mobile Device Using HTML5

摘要&#xff1a;As the mobile phone has become more mature, the continuous development of both hardware and software has become increasingly popular. Nowadays the need to develop mobile application that can run over multi-platform is an essential problem b…

java: 程序包com.github.pagehelper不存在_Rust语言正在兴起,Java、Python、C的末日来临?...

您可能从未用Mozilla创建的开源&#xff0c;系统级编程语言Rust编写任何东西&#xff0c;但是您可能会在某个时候写。在Stack Overflow的2019年开发人员调查中&#xff0c;开发人员将Rust评为“最受欢迎的”语言&#xff0c;而Redmonk在半年的语言排名中&#xff0c;Rust 跻身前…

计算机应用与网络文化,计算机文化与应用基础

全国计算机等级考试一级(2013年版)教学用书。主要介绍了计算机基础概述、中文Windows 7 操作、计算机网络基础、中文Word 2010操作、中文Excel 2010操作、中文PowerPoint 2010操作等内容。书 名计算机文化基础(Windows 7Office 2010)作 者李淑华ISBN978-7-04-037945-7页 …

惠安七号机器人创意园_我是F518创意园,请为我投票!

春去秋来&#xff0c;一个轮回又一年。“ 你知道F518创意园开园多久了吗&#xff1f;对的&#xff0c;13年&#xff01;”作为深圳实施“腾笼换鸟”首批项目和深圳申请联合国科教文组织“设计之都”重要组成部分&#xff0c;我们开园至今已经13年了&#xff01;白驹过隙&#x…