鱼C论坛

 找回密码
 立即注册
查看: 3076|回复: 0

[技术交流] 归并排序

[复制链接]
发表于 2020-10-27 17:30:44 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
# 单行输入多个变量的话,用input().split()读入并分解成列表
# 多个整数在一行,则用list(map(int,input().split()))来获取
# merge sort:归并排序

  1. def merge_sort(lst):
  2.     if len(lst) <= 1:
  3.         return lst
  4.     middle = int(len(lst) / 2)
  5.     left = merge_sort(lst[:middle])
  6.     right = merge_sort(lst[middle:])
  7.     merged = []
  8.     while left and right:
  9.         merged.append(left.pop(0) if left[0] <= right[0] else right.pop(0))
  10.     merged.extend(right if right else left)
  11.     return merged


  12. data_lst = [6, 202, 100, 301, 38, 8, 1]
  13. print(merge_sort(data_lst))
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-28 21:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表