十大排序算法介绍及python实现(python3 排序算法)
off999 2024-10-27 11:50 24 浏览 0 评论
排序算法
排序算法简单地分为两类:比较排序和非比较排序,其中比较排序是通过比较元素的相对大小来实现排序,其复杂度的上限为O(nlogn),所以也称其为非线性时间排序;非比较排序不是通过比较元素相对大小来实现,通常能够以O(n)的复杂度来实现,所以也称其为线性时间排序,下面给出了十种排序算法的复杂度(时间复杂度和空间复杂度)和稳定性
其中,n 表示需要排序的元素数量,k 表示桶的数量
LB三人组
冒泡排序
冒泡排序的思想就是每次循环过程中,大的元素下降,小的元素上升,从而进行排序,具体过程如下:
代码如下:
def bubble_sort(a):
n = len(a)
flag = False #设置标志位,避免无效排序
for i in range(n-1, 0, -1):
for j in range(i):
if a[j] > a[j + 1]:
a[j], a[j + 1] = a[j + 1], a[j]
flag = True
if not flag:
break
return a
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(bubble_sort(a))
选择排序
选择排序的思想就是每次循环的过程中找到最小的值放在第一位,依次循环找到其他较小的值放在接下来的位置,通过查找进行排序,其过程如下:
代码如下:
def select_sort(a):
n = len(a)
for i in range(n - 1):
min_index = i
for j in range(i+1, n):
if a[j] < a[min_index]:
min_index = j
a[i], a[min_index] = a[min_index], a[i]
return a
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(select_sort(a))
插入排序
插入排序的思想就是和之前的元素进行比较,大的元素放在后面,小的元素放在前面,具体过程如下:
代码如下:
def insert_sort(a):
n = len(a)
for i in range(1, n):
cur_val = a[i]
pos = i
while pos > 0 and a[pos - 1] > cur_val:
a[pos] = a[pos - 1]
pos -= 1
a[pos] = cur_val
return a
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(insert_sort(a))
希尔排序
希尔排序是插入排序的另一种变化,通过有间隔的插入排序并逐步减小间隔实现最终的排序,其过程如下:
代码如下:
def shell_sort(a):
n = len(a)
gap = n // 2
while gap > 0:
for i in range(gap):
gap_insert(a, i, gap) #有间隔的插入排序
gap //= 2
return a
def gap_insert(a, sta, gap):
for i in range(sta + gap, len(a), gap):
cur_val = a[i]
pos = i
while pos > sta and a[pos - gap] > cur_val:
a[pos] = a[pos - gap]
pos -= gap
a[pos] = cur_val
return a
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(shell_sort(a))
NB三人组
归并排序
归并排序是基于分治的思想,将需要排序的数据分为两个子序列,对子序列进行排序,然后将排好序的子序列进行合并实现最终的排序,过程如下:
代码如下:
def merge_sort(a):
if len(a) <= 1:
return a
n = len(a) // 2
left = merge_sort(a[:n]) #子序列归并排序
right = merge_sort(a[n:])
return merge(left, right) #合并排好序的子序列
def merge(left, right):
l, r = 0, 0
res = []
while l < len(left) and r < len(right):
if left[l] < right[r]:
res.append(left[l])
l += 1
else:
res.append(right[r])
r += 1
res.extend(left[l:])
res.extend(right[r:])
return res
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(merge_sort(a))
堆排序
堆排序思想是建立一个大根堆,将堆顶位置与最后一个进行交换,再建立大根堆,重复上述操作实现排序,过程如下:
代码如下:
def heap_sort(a):
n = len(a)
for i in range(n // 2 - 1, -1, -1):
siftdown(a, i, n - 1) #建立大根堆
for j in range(n - 1, 0, -1):
a[0], a[j] = a[j], a[0] #交换后,继续建立大根堆
siftdown(a, 0, j-1)
return a
def siftdown(a, sta, end):
root = sta #根节点
while True:
child = 2 * root + 1 #左孩子节点
if child > end:
break
if child + 1 <= end and a[child] < a[child + 1]: #存在右孩子节点
child += 1
if a[root] < a[child]: #维护大根堆
a[root], a[child] = a[child], a[root]
root = child
else:
break
return a
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(heap_sort(a))
快速排序
快速排序的思想是选择一个基准线,将比基准线小的放在一边,比基准线大的放在另一边,通过对两部分进行排序实现最终的排序,过程如下:
代码如下:
def quick_sort(a):
if len(a) <= 1:
return a
left = []
right = []
base = a.pop()
for x in a:
if x < base:
left.append(x)
else:
right.append(x)
return quick_sort(left) + [base] + quick_sort(right)
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(quick_sort(a))
线性时间排序
计数排序
计数排序的思想是建立计数器,统计每个数字出现的次数,再将统计的结果输出实现最终的排序,过程如下:
代码如下:
def count_sort(a):
n = len(a)
max_val = max(a)
count = [0] * (max_val + 1)
for i in range(n):
count[a[i]] += 1
res = []
for i in range(max_val + 1):
for j in range(count[i]):
res.append(i)
return res
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(count_sort(a))
桶排序
桶排序的思想就是将对应范围内的元素放进桶中,对桶中的元素进行排序,然后再将元素按照顺序取出,完成最终的排序,过程如下:
代码如下:
def bucket_sort(a,n=100,max_num=10000):
buckets = [[] for _ in range(n)] #创建桶
for x in a:
i = min(x // (max_num // n) , n - 1)
buckets[i].append(x) #将对应的数据放进桶中
for j in range(len(buckets[i]) - 1 , 0 ,-1):
if buckets[i][j] < buckets[i][j - 1]:
buckets[i][j] , buckets[i][j - 1] = buckets[i][j - 1] , buckets[i][j]
else:
break
result = []
for bin in buckets:
result.extend(bin)
return result
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(bucket_sort(a))
基数排序
基数排序的思想就是将整数按位分为不同的数字,对每个数字进行比较,具体过程如下:
代码如下:
def radix_sort(a):
max_val = max(a)
it = 0
while 10 ** it <= max_val:
buckets = [[] for _ in range(10)]
for x in a:
i = (x // (10 ** it)) % 10
buckets[i].append(x)
a = [j for i in buckets for j in i]
it += 1
return a
if __name__ == "__main__":
a = [90, 5, 83, 42, 12, 15]
print(radix_sort(a))
相关推荐
- pip的使用及配置_pip怎么配置
-
要使用python必须要学会使用pip,pip的全称:packageinstallerforpython,也就是Python包管理工具,主要是对python的第三方库进行安装、更新、卸载等操作,...
- Anaconda下安装pytorch_anaconda下安装tensorflow
-
之前的文章介绍了tensorflow-gpu的安装方法,也介绍了许多基本的工具与使用方法,具体可以看Ubuntu快速安装tensorflow2.4的gpu版本。pytorch也是一个十分流行的机器学...
- Centos 7 64位安装 python3的教程
-
wgethttps://www.python.org/ftp/python/3.10.13/Python-3.10.13.tgz#下载指定版本软件安装包tar-xzfPython-3.10.1...
- 如何安装 pip 管理工具_pip安装详细步骤
-
如何安装pip管理工具方法一:yum方式安装Centos安装python3和python3-devel开发包>#yuminstallgcclibffi-develpy...
- Python入门——从开发环境搭建到hello world
-
一、Python解释器安装1、在windows下步骤1、下载安装包https://www.python.org/downloads/打开后选择【Downloads】->【Windows】小编是一...
- 生产环境中使用的十大 Python 设计模式
-
在软件开发的浩瀚世界中,设计模式如同指引方向的灯塔,为我们构建稳定、高效且易于维护的系统提供了经过验证的解决方案。对于Python开发者而言,理解和掌握这些模式,更是提升代码质量、加速开发进程的关...
- 如何创建和管理Python虚拟环境_python怎么创建虚拟环境
-
在Python开发中,虚拟环境是隔离项目依赖的关键工具。下面介绍创建和管理Python虚拟环境的主流方法。一、内置工具:venv(Python3.3+推荐)venv是Python标准...
- 初学者入门Python的第一步——环境搭建
-
Python如今成为零基础编程爱好者的首选学习语言,这和Python语言自身的强大功能和简单易学是分不开的。今天千锋武汉Python培训小编将带领Python零基础的初学者完成入门的第一步——环境搭建...
- 全网最简我的世界Minecraft搭建Python编程环境
-
这篇文章将给大家介绍一种在我的世界minecraft里搭建Python编程开发环境的操作方法。目前看起来应该是全网最简单的方法。搭建完成后,马上就可以利用python代码在我的世界自动创建很多有意思的...
- Python开发中的虚拟环境管理_python3虚拟环境
-
Python开发中,虚拟环境管理帮助隔离项目依赖,避免不同项目之间的依赖冲突。虚拟环境的作用隔离依赖:不同项目可能需要不同版本的库,虚拟环境可以为每个项目创建独立的环境。避免全局污染:全局安装的库可...
- Python内置zipfile模块:操作 ZIP 归档文件详解
-
一、知识导图二、知识讲解(一)zipfile模块概述zipfile模块是Python内置的用于操作ZIP归档文件的模块。它提供了创建、读取、写入、添加及列出ZIP文件的功能。(二)ZipFile类1....
- Python内置模块pydoc :文档生成器和在线帮助系统详解
-
一、引言在Python开发中,良好的文档是提高代码可读性和可维护性的关键。pydoc是Python自带的一个强大的文档生成器和在线帮助系统,它可以根据Python模块自动生成文档,并支持多种输出格式...
- Python sys模块使用教程_python system模块
-
1.知识导图2.sys模块概述2.1模块定义与作用sys模块是Python标准库中的一个内置模块,提供了与Python解释器及其环境交互的接口。它包含了许多与系统相关的变量和函数,可以用来控制P...
- Python Logging 模块完全解读_python logging详解
-
私信我,回复:学习,获取免费学习资源包。Python中的logging模块可以让你跟踪代码运行时的事件,当程序崩溃时可以查看日志并且发现是什么引发了错误。Log信息有内置的层级——调试(deb...
- 软件测试|Python logging模块怎么使用,你会了吗?
-
Pythonlogging模块使用在开发和维护Python应用程序时,日志记录是一项非常重要的任务。Python提供了内置的logging模块,它可以帮助我们方便地记录应用程序的运行时信息、错误和调...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)