前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >python 排序

python 排序

原创
作者头像
织幻妖
修改于 2021-03-01 10:13:55
修改于 2021-03-01 10:13:55
68200
代码可运行
举报
运行总次数:0
代码可运行

1.插入排序

插入排序是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def insertionSort(arr):
    for i in range(1, len(arr)):
        key = arr[i]

        j = i - 1
        while j >= 0 and key < arr[j]:
            arr[j + 1] = arr[j]
            j -= 1
        arr[j + 1] = key


arr = [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
print("排序前的数组:", arr)
insertionSort(arr)
print("使用插入排序")
print("排序后的数组:", arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用插入排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

2.冒泡排序

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

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def bubbleSort(arr):
    n = len(arr)

    # 遍历所有数组元素
    for i in range(n):

        # Last i elements are already in place
        for j in range(0, n - i - 1):

            if arr[j] > arr[j + 1]:
                arr[j], arr[j + 1] = arr[j + 1], arr[j]


arr = [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
print("排序前的数组:", arr)
bubbleSort(arr)

print("使用冒泡排序")
print("排序后的数组:", arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用冒泡排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

3.归并排序

归并排序是创建在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。

分治法:

  • 分割:递归地把当前序列平均分割成两半。
  • 集成:在保持元素顺序的同时将上一步得到的子序列集成到一起(归并)。

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def merge(arr, l, m, r):
    n1 = m - l + 1
    n2 = r - m

    # 创建临时数组
    L = [0] * (n1)
    R = [0] * (n2)

    # 拷贝数据到临时数组 arrays L[]R[]
    for i in range(0, n1):
        L[i] = arr[l + i]

    for j in range(0, n2):
        R[j] = arr[m + 1 + j]

        # 归并临时数组到 arr[l..r]
    i = 0  # 初始化第一个子数组的索引
    j = 0  # 初始化第二个子数组的索引
    k = l  # 初始归并子数组的索引

    while i < n1 and j < n2:
        if L[i] <= R[j]:
            arr[k] = L[i]
            i += 1
        else:
            arr[k] = R[j]
            j += 1
        k += 1

    # 拷贝 L[] 的保留元素
    while i < n1:
        arr[k] = L[i]
        i += 1
        k += 1

    # 拷贝 R[] 的保留元素
    while j < n2:
        arr[k] = R[j]
        j += 1
        k += 1


def mergeSort(arr, l, r):
    if l < r:
        m = int((l + (r - 1)) / 2)

        mergeSort(arr, l, m)
        mergeSort(arr, m + 1, r)
        merge(arr, l, m, r)


arr = [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]

n = len(arr)
print("排序前的数组:", arr)

mergeSort(arr, 0, n - 1)
print("使用归并排序")
print("排序后的数组:", arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用归并排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

4.快速排序

快速排序使用分治法(Divide and conquer)策略来把一个序列(list)分为较小和较大的2个子序列,然后递归地排序两个子序列。

步骤为:

  • 挑选基准值:从数列中挑出一个元素,称为"基准"(pivot);
  • 分割:重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面(与基准值相等的数可以到任何一边)。在这个分割结束之后,对基准值的排序就已经完成;
  • 递归排序子序列:递归地将小于基准值元素的子序列和大于基准值元素的子序列排序。

递归到最底部的判断条件是数列的大小是零或一,此时该数列显然已经有序。

选取基准值有数种具体方法,此选取方法对排序的时间性能有决定性影响。

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def partition(arr, low, high):
    i = (low - 1)  # 最小元素索引
    pivot = arr[high]

    for j in range(low, high):

        # 当前元素小于或等于 pivot
        if arr[j] <= pivot:
            i = i + 1
            arr[i], arr[j] = arr[j], arr[i]

    arr[i + 1], arr[high] = arr[high], arr[i + 1]
    return (i + 1)


# arr[] --> 排序数组
# low  --> 起始索引
# high  --> 结束索引

# 快速排序函数
def quickSort(arr, low, high):
    if low < high:
        pi = partition(arr, low, high)

        quickSort(arr, low, pi - 1)
        quickSort(arr, pi + 1, high)


arr = [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
n = len(arr)
print("排序前的数组:", arr)
quickSort(arr, 0, n - 1)
print("使用快速排序")
print("排序后的数组:", arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用快速排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

5.选择排序

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

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
arr = [9,1,8,2,7,3,6,4,0,5]
print("排序前的数组:",arr)
for i in range(len(arr)):

    min_idx = i
    for j in range(i + 1, len(arr)):
        if arr[min_idx] > arr[j]:
            min_idx = j

    arr[i], arr[min_idx] = arr[min_idx], arr[i]
print("使用选择排序")
print("排序后的数组:",arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用选择排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

6.堆排序

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

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def heapify(arr, n, i):
    largest = i
    l = 2 * i + 1  # left = 2*i + 1
    r = 2 * i + 2  # right = 2*i + 2

    if l < n and arr[i] < arr[l]:
        largest = l

    if r < n and arr[largest] < arr[r]:
        largest = r

    if largest != i:
        arr[i], arr[largest] = arr[largest], arr[i]  # 交换

        heapify(arr, n, largest)


def heapSort(arr):
    n = len(arr)

    # Build a maxheap.
    for i in range(n, -1, -1):
        heapify(arr, n, i)

        # 一个个交换元素
    for i in range(n - 1, 0, -1):
        arr[i], arr[0] = arr[0], arr[i]  # 交换
        heapify(arr, i, 0)


arr = [9,1,8,2,7,3,6,4,0,5]
print("排序前的数组:",arr)
heapSort(arr)
n = len(arr)
print("使用堆排序")
print("排序后的数组:",arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用堆排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

7.希尔排序

希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。

希尔排序的基本思想是:先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录"基本有序"时,再对全体记录进行依次直接插入排序。

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def shellSort(arr):
    n = len(arr)
    gap = int(n / 2)

    while gap > 0:

        for i in range(gap, n):

            temp = arr[i]
            j = i
            while j >= gap and arr[j - gap] > temp:
                arr[j] = arr[j - gap]
                j -= gap
            arr[j] = temp
        gap = int(gap / 2)


arr = [9,1,8,2,7,3,6,4,0,5]

n = len(arr)
print("排序前的数组:",arr)

shellSort(arr)

print("使用希尔排序")
print("排序后的数组:",arr)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前的数组: [9, 1, 8, 2, 7, 3, 6, 4, 0, 5]
使用希尔排序
排序后的数组: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

8.计数排序

计数排序的核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数。

代码演示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def countSort(arr):
    output = [0 for i in range(256)]

    count = [0 for i in range(256)]

    ans = ["" for _ in arr]

    for i in arr:
        count[ord(i)] += 1

    for i in range(256):
        count[i] += count[i - 1]

    for i in range(len(arr)):
        output[count[ord(arr[i])] - 1] = arr[i]
        count[ord(arr[i])] -= 1

    for i in range(len(arr)):
        ans[i] = output[i]
    return ans


arr = "qwerasdfzxcv"
print("字符数组排序前",arr)
ans = countSort(arr)
print("使用计数排序")
print ( "字符数组排序前",ans)

执行效果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
字符数组排序前 qwerasdfzxcv
使用计数排序
字符数组排序前 ['a', 'c', 'd', 'e', 'f', 'q', 'r', 's', 'v', 'w', 'x', 'z']

补充个小知识

有时候代码里面如果有中文,执行代码会报一下错

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
SyntaxError: Non-UTF-8 code starting with '\xd7' in file D:/PycharmProjects/python/kuaisupaixu.py on line 3, but no encoding declared; see http://python.org/dev/peps/pep-0263/ for details

这个是编码问题

需要在代码的最前面加上一行注释,就可以解决

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# -- coding: gbk --

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
吐血整理--史上最全排序算法Python实现
一般排序算法最常考的:快速排序和归并排序。这两个算法体现了分治算法的核心观点,而且还有很多出题的可能。
宇宙之一粟
2020/10/26
3700
八大排序算法总结与java实现
概述 因为健忘,加上对各种排序算法理解不深刻,过段时间面对排序就蒙了。所以决定对我们常见的这几种排序算法进行统一总结。首先罗列一下常见的十大排序算法: 请点击此处输入图片描述 我们讨论的这八大排序算法的实现可以参考我的Github:SortAlgorithms,其中也包括了排序测试模块[Test.java]和排序算法对比模块[Bench.java],大家可以试运行。 它们都属于内部排序,也就是只考虑数据量较小仅需要使用内存的排序算法,他们之间关系如下: 请点击此处输入图片描述 一、直接插入排序(In
企鹅号小编
2018/01/18
1.1K0
八大排序算法总结与java实现
十种排序方法
在C语言中,有多种排序算法可供选择,每种都有其独特的特点和应用场景。以下是几种常见的排序算法及其在C语言中的总结:
ljw695
2024/10/18
1380
数据结构与算法-十大排序算法(动画演示)
不稳定:如果a原本在b的前面,而a = b,排序之后 a 可能会出现在 b 的后面。
越陌度阡
2020/11/26
7650
数据结构与算法-十大排序算法(动画演示)
十大经典排序算法最强总结(含Java、Python码实现)
所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作。排序算法,就是如何使得记录按照要求排列的方法。排序算法在很多领域得到相当地重视,尤其是在大量数据的处理方面。一个优秀的算法可以节省大量的资源。在各个领域中考虑到数据的各种限制和规范,要得到一个符合实际的优秀算法,得经过大量的推理和分析。
10JQKA
2020/12/31
9990
十大排序——最全最详细,一文让你彻底搞懂
(注:文章中的算法顺序是按照下面的图片中的分类进行,你可以不按照这个顺序。根据你的个人喜好、时间以及上面的侧重点分析,按照自己的需求学习即可。)
全栈程序员站长
2022/09/15
9700
十大排序——最全最详细,一文让你彻底搞懂
Python实现排序算法
本章介绍使用Python实现场景的几种排序算法。分别有冒泡算法、快速排序、插入排序、希尔排序、选择排序、堆排序、归并排序、计数排序、桶排序、基数排序。
用户3577892
2020/06/11
5330
面试官:手撕十大排序算法,你会几种?
2020年7月24日,阴,气温15摄氏度,已经两天没有涨粉丝了,一个人运营公众号确实有些吃力。尽管这样,也不影响我前进的脚步,搬砖的路上,我们一起加油!!!
C you again
2020/09/10
4590
Python实现常见的排序算法
本章介绍使用Python实现场景的几种排序算法。分别有冒泡算法、快速排序、插入排序、希尔排序、选择排序、堆排序、归并排序、计数排序、桶排序、基数排序。
夜雨飘零
2020/06/02
4800
一起来用python实现一下十大经典排序算法
既然之前很多小伙伴反应希望公众号多发点算法类的文章,那就来呗。先从简单的入手好了,带大家用python来实现一波十大经典排序算法呗。分别是:
double
2020/07/22
9110
一起来用python实现一下十大经典排序算法
如何使用Go、Python、Java、Rust、C、JS等6种编程语言实现六大排序算法:插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序
排序算法是计算机科学中最基础也是最重要的概念之一。无论你是初学者还是资深开发者,理解并掌握排序算法对编程能力的提升至关重要。排序算法不仅是面试中的常见考题,它们在实际开发中也被广泛应用,例如在数据库查询、数据分析和大数据处理等领域。
猫头虎
2025/03/16
1280
四千字总结实现所有面试会考的排序算法【基于Python实现】
一般排序算法最常考的:快速排序和归并排序。这两个算法体现了分治算法的核心观点,而且还有很多出题的可能。
程序员迪迪
2022/01/05
2820
数据结构与算法 - 排序与搜索排序与搜索
冒泡排序(英语:Bubble Sort)是一种简单的排序算法。它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
Python攻城狮
2018/08/23
8500
数据结构与算法 - 排序与搜索排序与搜索
十大经典排序算法(动图演示)
不稳定:如果a原本在b的前面,而a=b,排序之后a可能会出现在b的后面。 时间复杂度:对排序数据的总的操作次数。反映当n变化时,操作次数呈现什么规律。 空间复杂度:是指算法在计算机内执行时所需存储空间的度量,它也是数据规模n的函数。
mathor
2018/08/03
4K0
十大经典排序算法(动图演示)
七种排序算法 冒泡,选择,插入,希尔,快速,归并,堆
排序算法可以说是数据结构与算法当中最为基础的部分,针对的是数组这一数据结构。将数组中的无序数据元素通过算法整理为有序的数据元素即为排序。
BUG弄潮儿
2021/04/26
5290
数列排序算法总结(Python实现)
非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序。
用户7886150
2021/01/14
5470
【转载】十大经典排序算法(动图演示)
冒泡排序是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
Ashen
2020/06/01
4790
【转载】十大经典排序算法(动图演示)
算法:排序
排序:就是将一组无序的记录序列按照某种逻辑顺序重新排序,调整为有序的记录序列的过程。简单的说,对于一组记录序列而言,就是根据记录的关键字递增顺序或者递减关系,将记录的次序进行重新排列,使得原来一组次序任意的记录序列转变为按其值有序排列的一组记录序列。
用户3578099
2022/04/18
1.2K0
算法:排序
十大经典排序算法动图演示+Python实现
而今天这篇文章,转自 Github 上一个项目,此项目整理了 10 个常见排序算法的原理、演示和多种语言的实现。这里我们摘录其中 Python 的实现,分享给大家。
Crossin先生
2020/01/16
1.4K0
十大经典排序算法动图演示+Python实现
Python数据结构与算法 实现八大经典排序算法
在面试题中可能会遇到排序算法,毕竟作为程序员内功心法,熟练掌握排序算法是很重要的,本文总结了八大经典排序算法的 Python 实现。排序算法是《数据结构与算法》中最基本的算法之一。排序算法可以分为内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存。常见的内部排序算法有:插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。
叶庭云
2021/12/01
3470
Python数据结构与算法  实现八大经典排序算法
相关推荐
吐血整理--史上最全排序算法Python实现
更多 >
LV.2
这个人很懒,什么都没有留下~
目录
  • 1.插入排序
  • 2.冒泡排序
  • 3.归并排序
  • 4.快速排序
  • 5.选择排序
  • 6.堆排序
  • 7.希尔排序
  • 8.计数排序
  • 补充个小知识
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档