算法-合并两个有序的数

这篇博客探讨了如何合并两个有序数组,通过对比元素并依次插入新数组实现。作者提到了这个过程与数据库中的sort merge Join操作相似,这种连接方式在Oracle、SQLServer和Hive等数据库中被使用,并简单介绍了其他类型的数据库连接方式。
摘要由CSDN通过智能技术生成

给定两个有序的数组arr1和arr2,将两个数组合并成一个新的有序数组
示例:

left_arr={1,4,7,9,19,25}
right_arr={3,5,7,14,26,37,49,50}
合并之后:
arr3={1,3,4,7,7,9,14,19,25,26,37,49,50}

-思路:定一个一个边长的数据,长度为两个数组的长之和;设想把两个数组分别左右顺序排序,然后同时遍历两个数组,对比left_arr[i]和right_arr[j]两个数,开始进行左右两个小的那个组放到arr3中,并且小的那边的数组index+1,而大的那边数据index不变,以此不停进行交替遍历,直至不能遍历为止,如果遇到左右两个数相等,则同时放到arr3中并且两个数组的index都+1,如果一方先遍历结束,怎该方数组不在index+1,另一方的数据以此放入arr3,左右数组都遍历结束则停止遍历,合并完毕,如下图:在这里插入图片描述
代码实现如下(Java):

public static void main(String[] args) {
   
        int[] left_arr={
   1,4,7,9,19,25};
        int[] right_arr=
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
题目描述: 给定两个长度分别为m和n的有序序列,求其中位。 输入格式: 第一行输入一个整m,表示第一个有序序列的长度。 第二行输入m个整,表示第一个有序序列。 第三行输入一个整n,表示第二个有序序列的长度。 第四行输入n个整,表示第二个有序序列。 输出格式: 输出一个整,表示两个有序序列的中位。 输入样例: 5 1 3 5 7 9 6 2 4 6 8 10 12 输出样例: 7 算法1: (二分查找) $O(log(min(m,n)))$ 1.先确定中位的位置,如果m+n为奇,则中位位置为(m+n+1)/2,如果为偶,则中位位置为(m+n)/2和(m+n)/2+1。 2.在两个有序序列中分别进行二分查找,找到第一个序列中第k/2个和第二个序列中第k/2个,比较两个的大小,如果第一个序列中的小,则第一个序列中前k/2个都不可能是中位,将第一个序列中前k/2个舍去,更新k值,继续在剩下的中查找中位。 3.重复步骤2,直到找到中位。 时间复杂度 二分查找的时间复杂度为O(log(min(m,n))),因此总时间复杂度为O(log(min(m,n)))。 C++ 代码 算法2: (归并排序) $O(m+n)$ 1.将两个有序序列合并成一个有序序列。 2.如果合并后的序列长度为奇,则中位合并后序列的中间位置的,如果长度为偶,则中位为中间位置的两个的平均值。 时间复杂度 归并排序的时间复杂度为O(m+n),因此总时间复杂度为O(m+n)。 C++ 代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值