小编教你python常见算法。

Python常见算法

冒泡排序(Bubble Sort)

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

小编教你python常见算法。

def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        for j in range(0, n-i-1):
            if arr[j] > arr[j+1]:
                arr[j], arr[j+1] = arr[j+1], arr[j]

选择排序(Selection Sort)

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

def selection_sort(arr):
    n = len(arr)
    for i in range(n):
        min_idx = i
        for j in range(i+1, n):
            if arr[j] < arr[min_idx]:
                min_idx = j
        arr[i], arr[min_idx] = arr[min_idx], arr[i]

插入排序(Insertion Sort)

插入排序的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入,插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

def insertion_sort(arr):
    n = len(arr)
    for i in range(1, n):
        key = arr[i]
        j = i-1
        while j >= 0 and key < arr[j]:
            arr[j+1] = arr[j]
            j -= 1
        arr[j+1] = key

快速排序(Quick Sort)

快速排序是一种分治法策略的排序算法,它的工作原理如下,首先选择一个基准元素,通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

def quick_sort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]
    left = [x for x in arr if x < pivot]
    middle = [x for x in arr if x == pivot]
    right = [x for x in arr if x > pivot]
    return quick_sort(left) + middle + quick_sort(right)

相关问题与解答:

1、什么是冒泡排序?

小编教你python常见算法。

答:冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来,遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

2、选择排序的原理是什么?

答:选择排序首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾,以此类推,直到所有元素均排序完毕。

3、插入排序是如何工作的?

答:插入排序通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入,插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

小编教你python常见算法。

4、快速排序的基本原理是什么?

答:快速排序是一种分治法策略的排序算法,首先选择一个基准元素,通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

本文来自投稿,不代表科技代码立场,如若转载,请注明出处https://www.cwhello.com/485941.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
硬件大师硬件大师订阅用户
上一篇 2024年7月12日 10:19
下一篇 2024年7月12日 10:29

相关推荐

  • 第十章排序算法:冒泡排序及选择排序

    说明:排序就是对某组数据进行升序或降序的排列方式,排序都是对索引数组 冒泡排序 从大到小排列-从小到大排列 找到从最大的下标的值和前面的值进行比较,如果前面小于后面的值,进行位置交换,以此类推一直找当前…

    2018年4月8日 PHP自学教程
    0268
  • 我来教你python内置标准库的功能是什么。

    Python的内置标准库包含多个以C编写的模块,这些模块提供了实现系统级功能的关键工具,如文件I/O。还有大量以Python编写的模块,它们为日常编程中的问题提供了标准解决方案。常用的有四个标准库:os、sys、re和rand…

    2024年7月8日
    00
  • stlmap排序。

    Storm是一个开源的分布式实时计算系统,它能够处理大量的数据流并进行实时计算,在Storm中,我们可以使用Topology来实现实时排序TopN的功能,下面将详细介绍如何使用Storm进行实时排序TopN的操作。 我们需要创建一…

    2024年6月13日
    00
  • python引用计数。

    Python引用计数 在Python中,垃圾收集是自动进行的,其核心机制是引用计数(Reference Counting),这是一种简单而直观的方法来跟踪和回收不再使用的内存,本文将详细探讨Python中的引用计数机制,包括它是如何工作…

    15小时前
    00
  • 我来教你python 平面拟合。

    在数据分析和科学研究中,平面拟合是一种常用的技术手段,它可以帮助研究人员找到最佳匹配数据的平面模型,Python 提供了丰富的库来进行这样的拟合,如 numpy、scipy 以及 matplotlib 等。 平面拟合简介 平面拟合通…

    5天前
    00

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息