设计一个算法,将给定的两个降(升)序序列归并为一个降(升)序序列,
并分析算法时间复杂度。(设两个序列分别用数组 A[n]和 B[m]表示,合并后的序
列用数组 C[n+m]表示)
设计一个算法,将给定的两个降(升)序序列归并为一个降(升)序序列, 并分析算法时间复杂度。(设两个序列分别用数组 A[n]和 B[m]表示,合并后的序 列用数组 C[n+m]表示)
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- fuill 2022-03-04 14:32关注
简单合并,时间复杂度为O(n+m)
#include<stdio.h> void merge(int a[],int n,int b[],int m,int c[]) { int ap=0,bp=0,cp=0; for(int j=0; j<n+m; j++) { if(ap==n) { c[cp++]=b[bp++]; continue; } if(bp==m) { c[cp++]=a[ap++]; continue; } if(a[ap]<b[bp]) c[cp++]=a[ap++]; else c[cp++]=b[bp++]; } } int main() { int n=12,m=9; int a[]= {1,2,5,9,11,12,16,20,55,59,60,66}; int b[]= {2,3,6,8,15,16,17,25,28}; int c[n+m]; /*int n=5,m=6; int a[]={15,12,11,9,6}; int b[]={16,14,10,8,7,6}; int c[n+m];*/ merge(a,n,b,m,c); for(int j=0; j<n+m; j++) printf("%d ",c[j]); return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 数学建模招标中位数问题
- ¥15 phython路径名过长报错 不知道什么问题
- ¥15 深度学习中模型转换该怎么实现
- ¥15 HLs设计手写数字识别程序编译通不过
- ¥15 Stata外部命令安装问题求帮助!
- ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
- ¥15 TYPCE母转母,插入认方向
- ¥15 如何用python向钉钉机器人发送可以放大的图片?
- ¥15 matlab(相关搜索:紧聚焦)
- ¥15 基于51单片机的厨房煤气泄露检测报警系统设计