python两个数组合并排序_合并Python中的排序数组

假设我们有两个排序数组A和B。我们必须将它们合并并仅形成一个排序数组C。列表的大小可能不同。

例如,假设A = [1,2,4,7]和B = [1,3,4,5,6,8],则合并列表C将为[1,1,2,3,4, 4,5,6,7,8]

为了解决这个问题,请遵循以下步骤-定义i:= 0,j:= 0,结束:= A – 1的长度

而end> = 0而不是A [end],结束:=结束– 1

而j 结束而不是A [i],则A [i]:= B [j],并将j增加1

否则,如果A [i]> B [j],则执行shift(A,i),A [i]:= B [j],将end和j加1

使我增加1

shift方法将如下所示工作-接受输入num_arr,然后我

j:= num_arr的长度– 1

而不是num_arr [j]做j:= j – 1

当j> = i时,做num_arr [j + 1] = num_arr [j],而j:= j – 1

让我们看一下实现以获得更好的理解

示例class Solution(object):

def merge(self, nums1, m, nums2, n):

i = 0

j = 0

end = len(nums1)-1

while end>=0 and not nums1[end]:

end-=1

while j

if i>end and not nums1[i]:

nums1[i] = nums2[j]

j+=1

elif nums1[i]>nums2[j]:

self.shift(nums1,i)

nums1[i] = nums2[j]

end+=1

j+=1

i+=1

return nums1

def shift(self,num,i):

j = len(num)-1

while not num[j]:

j-=1

while j>=i:

num[j+1] = num[j]

j-=1

ob = Solution()print(ob.merge([1,2,3,0,0,0],3,[2,5,6],3))

输入项[1,2,3,0,0,0]

[2,5,6]

输出结果[1, 2, 2, 3, 5, 6]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值