排序算法

      在算法中,无外乎最重要的就是排序算法,尤其是在面试中经常会被问到什么冒泡排序,选择排序,插入排序等等,那么在这次文章中介绍以python为例的排序算法。

1、冒泡排序:就是重复遍历要排序序列,然后依次按照索引去比较两个元素大小,最后将最大或者最小值浮到序列末端

def bubble_sort(alist):

方案一:

n = len(alist)

# 找到列表冒泡最大值需要的次数

for j in range(0,n-1):

# 每一次找到最大值需要的比较次数

for i in range(0,n-1-j):

if alist[i] > alist[i+1]:

alist[i],alist[i+1] = alist[i+1],alist[i]

    方案二:

    for j in range(len(alist)-1,0,-1):

    for i in range(j):

    if alist[i] > alist[i+1]:

    alist[i],alist[i+1] = alist[i+1],alist[i]

if __name__ == '__main__':

li=[12,8,39,9,4,73,82,23,21]

bubble_sort(li)

print(li)

2、选择排序:将未排序的序列选择最大或最小值,然后放在已经排序好的末端组成一个新的序列

def selecet_sort(alist):

n = len(alist)

# 需要进行多少次选择操作

for i  in range(n-1):

min_index = i

# 从i+1位置到末尾选择出最小数据

for j in range(i+1,n):

if alist[min_index] > alist[j]:

min_index = j

alist[min_index],alist[i] = alist[i],alist[min_index]

if __name__ == '__main__':

li=[333,32,433,13,9,44,12,53]

selecet_sort(li)

print('排序后:    ',li)

3、插入排序:将未排序的序列依次取出来然后放在已经排序序列中的正确位置上而组成新的序列

def insert_sort(alist):

n = len(alist)

for i in range(1,n):

for j in range(i,0,-1):

if alist[j] < alist[j-1]:

alist[j],alist[j-1] = alist[j-1],alist[j]

# i = j

# while i>0:

# if alist[i]

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 5,257评论 0 1
  • 排序算法 冒泡排序 选择排序 插入排序 快速排序(最常见) 希尔排序 归并排序 源码:Sorting 冒泡排序 冒...
    廖少少阅读 7,611评论 12 101
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,357评论 0 33
  • Ba la la la ~ 读者朋友们,你们好啊,又到了冷锋时间,话不多说,发车! 1.冒泡排序(Bub...
    王饱饱阅读 5,782评论 0 7
  • 不知道从什么时候开始,我特怕扔东西,于是养成了打扫剩菜、剩饭、剩水果的习惯。老头和孩子走后,我一个人坐在餐桌前...
    写在时间前面阅读 3,226评论 1 6

友情链接更多精彩内容