设计一个算法,将给定的两个降(升)序序列归并为一个降(升)序序列,
并分析算法时间复杂度。(设两个序列分别用数组 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 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改
- ¥20 wireshark抓不到vlan
- ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
- ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
- ¥15 stata安慰剂检验作图但是真实值不出现在图上
- ¥15 c程序不知道为什么得不到结果
- ¥40 复杂的限制性的商函数处理
- ¥15 程序不包含适用于入口点的静态Main方法
- ¥15 素材场景中光线烘焙后灯光失效