python列表排序有哪些

python列表排序有哪些,第1张

概述python列表排序有哪些

python列表排序:1、冒泡排序,是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来;2、插入排序,通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

相关学习推荐:python教程

1、冒泡排序

冒泡排序(Bubble Sort)是一种简单的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

def bubble_sort(List):    n = len(List)    for i in range(n - 1):        for j in range( 0,n - 1 - i):            if List[j] > List[j + 1]:                List[j], List[j + 1] = List[j + 1], List[j]        # if List[i] > List[i + 1]:        #     List[i], List[i + 1] = List[i + 1], List[i]    print(List)List=[2,4,6,8,1,3,5,7,9]bubble_sort(List)#结果:[1,2,3,4,5,6,7,8,9]

2、插入排序

插入排序(Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,在从后向前的扫描过程中,需要把已排序元素逐步向后挪位,为最新元素提供插入空间。

def insertion_sort(List):  n = len(List)  for i in range(1, n):    for j in range(i, 0, -1):      if List[j] < List[j - 1]:        List[j], List[j - 1] = List[j - 1], List[j]      else:        break  print(List)insertion_sort([3,0,2,5,8,5,9,41,0,1,6])#结果:[0, 0, 1, 2, 3, 5, 5, 6, 8, 9, 41]

3、选择排序

选择排序(Selection Sort )是一种简单直观的排序算法。它的工作原理如下:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后再从剩余未排序元素中继续寻找最小(大)元素。放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

def selection_sort(List):    n = len(List)    for i in range(0, n -1):        min_index = i        for j in range(i + 1, n):            if List[min_index] > List[j]:                min_index = j        if i != min_index:            List[min_index], List[i] = List[i], List[min_index]    print(List)selection_sort([5,9,6,42,9,4,66,2,3,0,1])#结果:0, 1, 2, 3, 4, 5, 6, 9, 9, 42, 66]

总结:

import random# 随机生成1-1000之间无序序列整数数据def generator():    random_data = []    for i in range( 0, 10 ):        random_data.append( random.randint( 1, 1000 ) )    return random_data# 冒泡排序def bubble_sort(List):    # 序列长度    n = len( List )    for i in range( 0, n ):        for j in range( i , n ):            if List[i] > List[j]:                List[i], List[j] = List[j], List[i]    return List # 选择排序def selection_sort(List):    n = len(List)    for i in range(0, n -1):        min_index = i        for j in range(i + 1, n):            if List[min_index] > List[j]:                min_index = j        if i != min_index:            List[min_index], List[i] = List[i], List[min_index]    return List#插入排序def insertion_sort(List):  n = len(List)  for i in range(1, n):    for j in range(i, 0, -1):      if List[j] < List[j - 1]:        List[j], List[j - 1] = List[j - 1], List[j]      else:        break  return Listif __name__ == "__main__":    # 生成随机无序数据    List = generator()    # 打印无序数据    print( '随机生成的无序数据:',List )    # 冒泡排序    sorted_data = bubble_sort( List )    #插入排序    insertion_data=insertion_sort(List)    #选择排序    selection_data=selection_sort( List )    # 打印排序结果    print( '冒泡排序:',sorted_data )    print( '插入排序:', insertion_data )    print( '选择排序:', selection_data )'''结果:随机生成的无序数据: [300, 517, 591, 209, 204, 789, 417, 739, 803, 393]冒泡排序: [204, 209, 300, 393, 417, 517, 591, 739, 789, 803]插入排序: [204, 209, 300, 393, 417, 517, 591, 739, 789, 803]选择排序: [204, 209, 300, 393, 417, 517, 591, 739, 789, 803]'''

想了解更多编程学习,敬请关注php培训栏目!

总结

以上是内存溢出为你收集整理的python列表排序有哪些全部内容,希望文章能够帮你解决python列表排序有哪些所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1183902.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-03
下一篇 2022-06-03

发表评论

登录后才能评论

评论列表(0条)

保存