排序算法及其实现

在计算机科学中,排序算法是一种将一组数据按照特定顺序进行排列的算法。排序算法在日常生活和计算机科学中都扮演着重要的角色,例如在电子表格中对数据进行排序,或者在数据库中对记录进行排序。本文将介绍几种常见的排序算法,并使用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]
    return arr

选择排序(Selection Sort)

选择排序是一种简单直观的排序算法。它的工作原理是每次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。

python 复制代码
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]
    return arr

插入排序(Insertion Sort)

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

python 复制代码
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
    return arr

以上是三种常见的排序算法及其Python实现。每种排序算法都有其适用的场景和性能特点,选择合适的排序算法可以提高程序的效率。

相关推荐
wuk9984 分钟前
基于位置式PID算法调节PWM占空比实现电机转速控制
单片机·嵌入式硬件·算法
mit6.82415 分钟前
[tile-lang] 语言接口 | `T.prim_func` & `@tilelang.jit` | 底层原理
python
不到满级不改名19 分钟前
EM算法 & 隐马尔可夫模型
算法
凡间客22 分钟前
Python编程之常用模块
开发语言·python
景彡先生22 分钟前
Python基础语法规范详解:缩进、注释与代码可读性
开发语言·前端·python
liliangcsdn1 小时前
python如何写数据到excel示例
开发语言·python·excel
CNRio2 小时前
将word和excel快速转换为markdown格式
python·word·excel
workflower4 小时前
单元测试-例子
java·开发语言·算法·django·个人开发·结对编程
小白银子4 小时前
零基础从头教学Linux(Day 52)
linux·运维·服务器·python·python3.11
AAA小肥杨6 小时前
基于k8s的Python的分布式深度学习训练平台搭建简单实践
人工智能·分布式·python·ai·kubernetes·gpu