返回顶部
首页 > 资讯 > 后端开发 > Python >python3如何实现常见的排序算法
  • 240
分享到

python3如何实现常见的排序算法

2023-06-20 13:06:40 240人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

小编给大家分享一下python3如何实现常见的排序算法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!冒泡排序冒泡排序是一种简单的排序算法。它重复地走访过要排序的数

小编给大家分享一下python3如何实现常见的排序算法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

冒泡排序

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

python3如何实现常见的排序算法

def mao(lst):    for i in range(len(lst)):        # 由于每一轮结束后,总一定有一个大的数排在后面        # 而且后面的数已经排好了        # 即i轮之后,就有i个数字被排好        # 所以其 len-1 -i到 len-1的位置是已经排好的了        # 只需要比较0到len -1 -i的位置即可        # flag 用于标记是否刚开始就是排好的数据        # 只有当flag状态发生改变时(第一次循环就可以确定),继续排序,否则返回        flag = False        for j in range(len(lst) - i - 1):            if lst[j] > lst[j + 1]:                lst[j], lst[j + 1] = lst[j + 1], lst[j]                flag = True                # 非排好的数据,改变flag        if not flag:            return lst    return lstprint(mao([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))

选择排序

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

python3如何实现常见的排序算法

# 选择排序是从前开始排的# 选择排序是从一个列表中找出一个最小的元素,然后放在第一位上。# 冒泡排序类似# 其 0 到 i的位置是排好的,只需要排i+1到len(lst)-1即可def select_sort(lst):    for i in range(len(lst)):        min_index = i  # 用于记录最小的元素的索引        for j in range(i + 1, len(lst)):            if lst[j] < lst[min_index]:                min_index = j        # 此时,已经确定,min_index为 i+1 到len(lst) - 1 这个区间最小值的索引        lst[i], lst[min_index] = lst[min_index], lst[i]    return lstdef select_sort2(lst):    # 第二种选择排序的方法    # 原理与第一种一样    # 不过不需要引用中间变量min_index    # 只需要找到索引i后面的i+1到len(lst)的元素即可    for i in range(len(lst)):        for j in range(len(lst) - i):            # lst[i + j]是一个i到len(lst)-1的一个数            # 因为j <= len(lst) -i 即 j + i <= len(lst)            if lst[i] > lst[i + j]:                # 说明后面的数更小,更换位置                lst[i], lst[i + j] = lst[i + j], lst[i]    return lstprint(select_sort([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))print(select_sort2([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))

快速排序

快速排序是通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。

python3如何实现常见的排序算法

# 原理# 1. 任取列表中的一个元素i# 2. 把列表中大于i的元素放于其右边,小于则放于其左边# 3. 如此重复# 4. 直到不能在分,即只剩1个元素了# 5. 然后将这些结果组合起来def quicksort(lst):    if len(lst) < 2:    # lst有可能为空        return lst    # ['pɪvət] 中心点    pivot = lst[0]    less_lst = [i for i in lst[1:] if i <= pivot]    greater_lst = [i for i in lst[1:] if i > pivot]    # 最后的结果就是    #           左边的结果 + 中间值 + 右边的结果    # 然后细分   左+中+右   + 中间值 + 左 + 中+ 右    #      ...........    + 中间值 + ............    return quicksort(less_lst) + [pivot] + quicksort(greater_lst)print(quicksort([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))print(quicksort([1, 5, 8, 62]))

插入排序

插入排序的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

python3如何实现常见的排序算法

# lst的[0, i) 项是有序的,因为已经排过了# 那么只需要比对第i项的lst[i]和lst[0 : i]的元素大小即可# 假如,lst[i]大,则不用改变位置#     否则,lst[i]改变位置,插到j的位置,而lst[j]自然往后挪一位#     然后再删除lst[i+1]即可(lst[i+1]是原来的lst[i])## 重复上面步骤即可,排序完成def insert_sort(lst: list):    # 外层开始的位置从1开始,因为从0开始都没得排    # 只有两个元素以上才能排序    for i in range(1, len(lst)):        # 内层需要从0开始,因为lst[0]的位置不一定是最小的        for j in range(i):            if lst[i] < lst[j]:                lst.insert(j, lst[i])                # lst[i]已经插入到j的位置了,j之后的元素都往后+1位,所以删除lst[i+1]                del lst[i + 1]    return lstprint(insert_sort([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))

希尔排序

希尔排序是1959年shell发明的,第一个突破O(n2)的排序算法,是简单插入排序的改进版。它与插入排序的不同之处在于,它会优先比较距离较远的元素。希尔排序又叫缩小增量排序。

python3如何实现常见的排序算法

希尔排序

# 希尔排序是对直接插入排序的优化版本# 1. 分组:#       每间隔一段距离取一个元素为一组#       间隔自己确定,一般为lst的一半# 2. 根据插入排序,把每一组排序好# 3. 继续分组:#         同样没间隔一段距离取一个元素为一组#         间隔要求比  之前的间隔少一半# 4. 再每组插入排序# 5. 直到间隔为1,则排序完成#def shell_sort(lst):    lst_len = len(lst)    gap = lst_len // 2  # 整除2,取间隔    while gap >= 1:  # 间隔为0时结束        for i in range(gap, lst_len):            temp = lst[i]            j = i            # 插入排序            while j - gap >= 0 and lst[j - gap] > temp:                lst[j] = lst[j - gap]                j -= gap            lst[j] = temp        gap //= 2    return lstprint(shell_sort([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))# 奇数#       gap = 2# [5, 2, 4, 3, 1]# [5, 4, 1] [2, 3]# [1, 4, 5, 2, 3]#       gap = 1# [1, 2, 3, 4, 5]# 偶数#       gap = 3# [5, 2, 4, 3, 1, 6]# [5, 3] [2, 1] [4,6]# [3, 5, 1, 2, 4 , 6]#       gap = 1# [1, 2, 3, 4, 5, 6]

并归排序

归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为2-路归并。

python3如何实现常见的排序算法

并归排序

# 利用分治法# 不断将lst分为左右两个分# 直到不能再分# 然后返回# 将两边的列表的元素进行比对,排序然后返回# 不断重复上面这一步骤# 直到排序完成,即两个大的列表比对完成def merge(left, right):    # left 可能为只有一个元素的列表,或已经排好序的多个元素列表(之前调用过merge)    # right 也一样    res = []    while left and right:        item = left.pop(0) if left[0] < right[0] else right.pop(0)        res.append(item)    # 此时,left或right已经有一个为空,直接extend插入    # 而且,left和right是之前已经排好序的列表,不需要再操作了    res.extend(left)    res.extend(right)    return resdef merge_sort(lst):    lst_len = len(lst)    if lst_len <= 1:        return lst    mid = lst_len // 2    lst_right = merge_sort(lst[mid:len(lst)])       # 返回的时lst_len <= 1时的 lst 或 merge中进行排序后的列表    lst_left = merge_sort(lst[:mid])                # 返回的是lst_len <= 1时的 lst 或 merge中进行排序后的列表    return merge(lst_left, lst_right)               # 进行排序,lst_left lst_right 的元素会不断增加print(merge_sort([1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]))

堆排序

堆排序是指利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。然后进行排序。

python3如何实现常见的排序算法

堆排序

# 把列表创成一个大根堆或小根堆# 然后根据大(小)根堆的特点:根节点最大(小),逐一取值## 升序----使用大顶堆## 降序----使用小顶堆# 本例以小根堆为例# 列表lst = [1, 22 ,11, 8, 12, 4, 9]# 1. 建成一个普通的堆:#          1#        /   \#       22    11#      / \    / \#     8  12  4   9## 2. 进行调整,从子开始调整位置,要求: 父节点<= 字节点##          1                                    1                                    1#        /   \         13和22调换位置         /   \          4和11调换位置          / \#       22    11       ==============>      13     11       ==============>       13    4#      / \    / \                          / \    /  \                           / \   /  \#     13  14 4   9                       22  14  4    9                        22  14 11   9## 3. 取出树上根节点,即最小值,把换上叶子节点的最大值##                   1#                  /#             ~~~~/#          22#         /   \#        8     4#         \   /  \#         12 11   9## 4. 按照同样的道理,继续形成小根堆,然后取出根节点,。。。。重复这个过程##          1                    1                 1  4                1 4           1 4 8           1 4 8#           /                    /                  /                    /             /                 /#       ~~~/                 ~~~/               ~~~/                 ~~~/          ~~~/              ~~~/#      22                   4                 22                   8             22                9#     /   \               /   \              /   \               /   \          /   \             /  \#    8     4             8     9            8     9             12    9        12    9           12  11#     \   /  \            \   /  \           \   /               \   /              /                /#     12 11   9           12 11  22          12 11               22 11            11               22## 续上:#       1 4 8 9          1 4 8 9           1 4 8 9 11     1 4 8 9 11    1 4 8 9 11 12   ==>  1 4 8 9 11 12 22#            /                  /                  /                /              /#        ~~~/               ~~~/               ~~~/             ~~~/           ~~~/#       22                 11                22                12            22#      /   \              /   \             /                  /#     12    11           12    22          12                22## 代码实现def heapify(lst, lst_len, i):    """创建一个堆"""    less = i  # largest为最大元素的索引    left_node_index = 2 * i + 1  # 左子节点索引    right_node_index = 2 * i + 2  # 右子节点索引    # lst[i] 就是父节点(假如有子节点的话):    #    #                 lst[i]    #                  /   \    #      lst[2*i + 1]    lst[ 2*i + 2]    #    # 想要大根堆,即升序, 将判断左右子节点大小的 ‘>' 改为 ‘<' 即可    #    if left_node_index < lst_len and lst[less] > lst[left_node_index]:        less = left_node_index    if right_node_index < lst_len and lst[less] > lst[right_node_index]:        # 右边节点最小的时候        less = right_node_index    if less != i:        # 此时,是字节点大于父节点,所以相互交换位置        lst[i], lst[less] = lst[less], lst[i]  # 交换        heapify(lst, lst_len, less)        # 节点变动了,需要再检查一下def heap_sort(lst):    res = []    i = len(lst)    lst_len = len(lst)    for i in range(lst_len, -1, -1):        # 要从叶节点开始比较,所以倒着来        heapify(lst, lst_len, i)    # 此时,已经建好了一个小根树    # 所以,交换元素,将根节点(最小值)放在后面,重复这个过程    for j in range(lst_len - 1, 0, -1):        lst[0], lst[j] = lst[j], lst[0]  # 交换,最小的放在j的位置        heapify(lst, j, 0)      # 再次构建一个[0: j)小根堆 [j: lst_len-1]已经倒序排好了    return lstarr = [1, 5, 55, 4, 5, 1, 3, 4, 5, 8, 62, 7]print(heap_sort(arr))

以上是“python3如何实现常见的排序算法”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网Python频道!

--结束END--

本文标题: python3如何实现常见的排序算法

本文链接: https://lsjlt.com/news/297085.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python3如何实现常见的排序算法
    小编给大家分享一下python3如何实现常见的排序算法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!冒泡排序冒泡排序是一种简单的排序算法。它重复地走访过要排序的数...
    99+
    2023-06-20
  • python3实现常见的排序算法(示例代码)
    冒泡排序 冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列...
    99+
    2024-04-02
  • PHP如何实现常见排序算法
    本篇内容介绍了“PHP如何实现常见排序算法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、冒泡排序两两相比,每循环一轮就不用再比较最后一个...
    99+
    2023-07-01
  • Java实现常见排序算法的优化
    冒泡排序 冒泡排序的思想: 每次让当前的元素和它的下一个元素比较大小、如果前一个的元素大于后一个元素的话,交换两个元素。 这样的话经历一次扫描之后能确保数组的最后一个元素一定是数组中...
    99+
    2024-04-02
  • Java常见排序算法怎么实现
    本文小编为大家详细介绍“Java常见排序算法怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java常见排序算法怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。汇总:1. 冒泡排序每轮循环确定最值;...
    99+
    2023-06-29
  • Golang怎么实现常见排序算法
    这篇文章主要介绍“Golang怎么实现常见排序算法”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Golang怎么实现常见排序算法”文章能帮助大家解决问题。五种基础排序算法对比五种基础排序算法对比1、...
    99+
    2023-06-30
  • C++实现十大排序算法及排序算法常见问题
    目录前言0 概述1 冒泡排序2 选择排序3 插入排序4 希尔排序5 归并排序6 堆排序7 快速排序8 计数排序9 桶排序10 基数排序总结前言 本文为C++实现的十大排序算法及基于排...
    99+
    2024-04-02
  • Golang实现常见排序算法的示例代码
    目录前言五种基础排序算法对比1、冒泡排序2、选择排序3、插入排序4、快速排序前言 现在的面试真的是越来越卷了,算法已经成为了面试过程中必不可少的一个环节,你如果想进稍微好一点的公司,...
    99+
    2024-04-02
  • PHP实现常见排序算法的示例代码
    目录1、冒泡排序2、选择排序3、快速排序4、插入排序补充1、冒泡排序 两两相比,每循环一轮就不用再比较最后一个元素了,因为最后一个元素已经是最大或者最小。 function maop...
    99+
    2024-04-02
  • Java实现几种常见排序算法代码
    稳定度(稳定性)一个排序算法是稳定的,就是当有两个相等记录的关键字R和S,且在原本的列表中R出现在S之前,在排序过的列表中R也将会是在S之前。 排序算法分类 常见的有插入(插入排序/...
    99+
    2022-11-15
    Java 排序算法
  • Java实现常见的排序算法的示例代码
    目录一、优化后的冒泡排序二、选择排序三、插入排序四、希尔排序五、快速排序六、随机化快速排序七、归并排序八、可处理负数的基数排序一、优化后的冒泡排序 package com.yzh.s...
    99+
    2022-11-13
    Java常见排序算法 Java排序算法 Java排序
  • 浅谈Java常见的排序算法
    目录一、直接插入排序二、希尔排序三、冒泡排序四、快速排序五、选择排序(Selection Sort)六、堆排序七、归并排序一、直接插入排序 基本思想: 将一个记录插入到已排序的有序表...
    99+
    2024-04-02
  • 优化常见的java排序算法
    目录冒泡排序原始的写法优化一优化二选择排序方法一方法二堆排序建大堆来实现堆排建小堆来实现堆排插入排序实现优化一优化二归并排序递归实现归并排序优化来看O(n)的排序当然除了基于比较的排...
    99+
    2024-04-02
  • 十大排序算法总结(Python3实现)
    目录   一、概述 二、算法简介及代码展示 1.冒泡排序 2.简单选择排序 3.简单插入排序 4.堆排序 5.快速排序 6.希尔排序 7.归并排序 8.计数排序 9.桶排序 10.基数排序 11.#代码说明 三、感悟总结 排序算法大概是...
    99+
    2023-01-31
    十大 算法
  • C语言常见排序算法归并排序
    目录前言 一、归并排序1.1 基本思想1.2 算法思想1.3 程序设计思想1.4 程序实现1.5 归并排序的特性总结前言 本期为大家带来的是常见排序算法中的归并排序,博主在...
    99+
    2024-04-02
  • 常见的php排序算法有哪些
    常见的PHP排序算法有以下几种:1. 冒泡排序(Bubble Sort):依次比较相邻的两个元素,将较大的元素向后移动,直到最后一个...
    99+
    2023-08-25
    php
  • 介绍java中的常见排序算法
    Java中的排序算法主要包括以下几种: 冒泡排序(Bubble Sort)选择排序(Selection Sort)插入排序(Insertion Sort)快速排序(Quick Sort)归并排序(Merge Sort)堆排序(Heap So...
    99+
    2023-10-26
    算法 排序算法 数据结构 java 笔记 学习
  • Java排序算法之堆排序如何实现
    这篇文章主要介绍了Java排序算法之堆排序如何实现,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。二叉堆是完全二叉树或者是近似完全二叉树。二叉堆满足二个特性︰1.父结点的键值总...
    99+
    2023-06-21
  • Python实现排序方法常见的四种
    1.冒泡排序,相邻位置比较大小,将比较大的(或小的)交换位置 def maopao(a): for i in range(0,len(a)): for j...
    99+
    2024-04-02
  • Java数据结构之常见排序算法怎么实现
    这篇文章主要介绍“Java数据结构之常见排序算法怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java数据结构之常见排序算法怎么实现”文章能帮助大家解决问题。注:后续所说的复杂度 log,都...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作