python归并排序的基本思路
python归并排序的基本思路
基本思路
归纳排序是采用分治法的非常典型的应用。
1、先归还分解组,然后合并组。基本构想是将数组分解到最小,然后合并两个有序数组。
2、基本构想是比较两个数组的最前面的数量,谁小就先取谁,取后取相应的指针后移。
然后进行比较,直到一个组是空的,最后复制另一个组的剩馀部分即可。
实例
#归并排序
defmerge_sort(alist):
'''归并排序'''
n=len(alist)
ifn<=1:
returnalist
else:
mid=n//2
#left表示采用归并排序后形成的有序的新的列表
left_li=merge_sort(alist[:mid])
#right表示采用归并排序后形成的有序的新的列表
right_li=merge_sort(alist[mid:])
#将两个有序的子序列合并成一个新的整体
#merge(left,right)
left_pointer,right_pointer=0,0
result=[]
whileleft_pointer ifleft_li[left_pointer]<=right_li[right_pointer]: result.append(left_li[left_pointer]) left_pointer+=1 else: result.append(right_li[right_pointer]) right_pointer+=1 result+=left_li[left_pointer:] result+=right_li[right_pointer:] returnresult if__name__=='__main__': alist=[54,26,93,17,77,31,44,55,20] print(alist) sorted_alist=merge_sort(alist) print(sorted_alist) 以上就是python归并排序的基本思路,希望对大家有所帮助。更多Python学习教程请关注IT培训机构:千锋教育。
data:image/s3,"s3://crabby-images/6d37f/6d37fc784dfbe4be1f5079220f563b6b62670b0f" alt=""
猜你喜欢LIKE
相关推荐HOT
更多>>data:image/s3,"s3://crabby-images/5674c/5674c8e11251db5a2e3a4e396d72e6c10c920a26" alt=""
python函数中使用for循环
python函数中使用for循环1、在for循环中使用函数需要更长的执行时间,因为每次迭代都会调用该函数。2、如果for循环是在函数内部实现的,那么该...详情>>
2023-11-14 13:53:34data:image/s3,"s3://crabby-images/a2831/a28310f94eef72195b5da4e666ea898ac2d8af3f" alt=""
python3.1版本的特性有哪些
python3.1中的特性有哪些1、千位数格式化,可以在使用字符串格式化函数时直接完成。在格式化大数时,通常是每三位数放置逗号,使数字更易读(例...详情>>
2023-11-14 13:18:27data:image/s3,"s3://crabby-images/0d4d2/0d4d2cf43385305b76dd51725870159e0210e95d" alt=""
python__new__()和__init__()有什么区别?
在python中,__new__()不是一定要有,只有继承自object的类才有,该方法可以return父类(通过super(当前类名,cls).__new__())出来的实例,或者直...详情>>
2023-11-14 12:38:55data:image/s3,"s3://crabby-images/6a8df/6a8df31c384d45cf5f12497815ef33241bb3c2a3" alt=""
pythonwheel是什么
python的第一个主流打包格式是.egg文件,现在大家庭中又有了一个叫做Wheel(*.whl)的新成员。wheel“被设计成包含PEP376兼容安装(一种非常接近于...详情>>
2023-11-14 11:30:39热门推荐
pythonSymPy求极值
沸python归并排序和快速排序比较
热pythonpartition如何分割字符串
热pythonif-elif-else语句的使用注意
新python函数中使用for循环
python3.1版本的特性有哪些
python__new__()和__init__()有什么区别?
python作为小白该如何抉择python编辑器?
pythonwheel是什么
python如何定义一个函数
pythonpython是什么类型的语言
python怎么传参数
pythonshell是什么
python如何查看对象属性
技术干货
data:image/s3,"s3://crabby-images/3fb08/3fb086590b943d7b4386b2cda4e1c309373b156a" alt=""
data:image/s3,"s3://crabby-images/f0479/f0479c0a53c4f3df3a65a3a679c60d48e9c00f6b" alt=""
data:image/s3,"s3://crabby-images/8b90b/8b90bca02d4d14b9b44bdfb3ba318aeefb1c053d" alt=""
data:image/s3,"s3://crabby-images/5549b/5549b16066e1a71851394e4709bb8c6bb857e78e" alt=""
data:image/s3,"s3://crabby-images/5674c/5674c8e11251db5a2e3a4e396d72e6c10c920a26" alt=""
data:image/s3,"s3://crabby-images/a2831/a28310f94eef72195b5da4e666ea898ac2d8af3f" alt=""
data:image/s3,"s3://crabby-images/0d4d2/0d4d2cf43385305b76dd51725870159e0210e95d" alt=""