您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
这期内容当中小编将会给大家带来有关使用Python怎么合并两个有序数组,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
思路
按位循环比较两个数组,较小元素的放入新数组,下标加一(注意,较大元素对应的下标不加一),直到某一个下标超过数组长度时退出循环
假设两个源数组的长度不一样,那么假设其中短的数组用完了,即全部放入到新数组中去了,那么长数组中剩下的那一段就可以直接拿来放入到新数组中去了。
#coding=utf-8 #合并数据 test1 = [1,2,5,7,9] test2=[2,4,6,8,10,11,34,55] def mergetest(test1,test2): result =[] len1=len(test1) len2=len(test2) i=0 j=0 while i<len1 and j<len2: if test1[i]<=test2[j]: result.append(test1[i]) i+=1 else: result.append(test2[j]) j+=1 if i<len1: for z in range(i+1,len1): result.append(test1[z]) elif j<len2: for z in range(j+1,len2): result.append(test2[z]) return result print mergetest(test1,test2)
运行结果:
[1, 2, 2, 4, 5, 6, 7, 8, 9, 11, 34, 55]
add:链表情况下合并
def merge_link(link1,link2): head = single_link(0) first = head while link1!=None and link2!=None: if l1.val<=l2.val: head.next =l1 l1=l1.next else: head.next=l2 l2=l2.next head=head.next if l1!=None: head.next=l1 elif l2!=None: head.next=lw return first.next
上述就是小编为大家分享的使用Python怎么合并两个有序数组了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。