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(天然有序)。
- 合并:每次合并两个有序子数组时,用双指针
i和j分别遍历左右数组,按大小顺序将元素添加到结果列表,最后拼接剩余元素。- 数据流向:每一层递归的结果都是一个有序子数组,最终通过顶层合并得到完整的有序数组。
整个过程体现了 “分治思想”,时间复杂度为
O(n log n),空间复杂度为O(n)(用于存储中间结果)。

5162

被折叠的 条评论
为什么被折叠?



