【Python】归并排序

class Solution:
    def mergeSort(self,nums:list[int])->list[int]:
        if len(nums)<=1:
            return nums
        mid= len(nums)//2
        left_nums = self.mergeSort(nums[:mid])
        right_nums = self.mergeSort(nums[mid:])
        return self.merge(left_nums,right_nums)
    def merge(self,left_nums:list[int],right_nums:list[int])->list[int]:
        result=[]
        i=j=0
        while i <len(left_nums) and j<len(right_nums):
            if left_nums[i]<right_nums[j]:
                result.append(left_nums[i])
                i+=1
            else:
                result.append(right_nums[j])
                j+=1
        result.extend(left_nums[i:])
        result.extend(right_nums[j:])
        return result
if __name__=="__main__":
    solution=Solution()
    test_nums=[43,12,62,88,13,64,17,32]
    result=solution.mergeSort(test_nums)
    print(result)

思路:分解—排序—合并

mergeSort方法负责递归分解,将列表拆分成一对一对的小数组

merge方法负责判断、排序和合并

数据处理核心逻辑

  1. 分解:通过递归将数组不断二分,直到子数组长度为 1(天然有序)。
  2. 合并:每次合并两个有序子数组时,用双指针 i 和 j 分别遍历左右数组,按大小顺序将元素添加到结果列表,最后拼接剩余元素。
  3. 数据流向:每一层递归的结果都是一个有序子数组,最终通过顶层合并得到完整的有序数组。

整个过程体现了 “分治思想”,时间复杂度为 O(n log n),空间复杂度为 O(n)(用于存储中间结果)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值