python 排序算法 简书_使用 Python 实现几种常见的排序算法

冒泡排序

冒泡排序是最为基础的排序算法,其核心思想就是相邻元素两两比较,把较大的元素放到后面,在一轮比较完成之后,最大的元素就位于最后一个位置了,就好像是气泡,慢慢的浮出了水面一样。

def bubble_sort(data, reverse=False):

"""

:param data: list type data

:param reverse:

:return: list type data

"""

if not reverse:

for i in range(len(data) - 1):

for j in range(len(data) - 1 -i):

if data[j] > data[j+1]:

data[j], data[j+1] = data[j+1], data[j]

return data

else:

for i in range(len(data) - 1):

for j in range(len(data) - 1 -i):

if data[j] < data[j+1]:

data[j], data[j + 1] = data[j + 1], data[j]

return data

** 其实冒泡排序算法还是比较好理解的,只需要进行两次循环,最外层的循环代表排序元素的个数,内部循环则进行两两比较,时间复杂度为 O(n^2)。**

选择排序

选择排序,是逐个确定元素位置的思想。同样是 n 遍循环,第一轮时,每一个元素都与第一个元素比较,如果比第一个元素大,则与之交换,这样一轮过后,第一个元素就是最小的了,第二轮开始每个元素与第二个位置的元素比较,如果大,则与第二位置的元素交换,以此类推,达到排序的目的

def selection_sort(data, reverse=False):

"""

:param data: list type data

:param reverse:

:return: list type data

"""

if not reverse:

for i in range(len(data)-1):

min_index = i

for j in range(i+1, len(data)):

if data[j] < data[min_index]:

min_index = j

data[i], data[min_index] = data[min_index], data[i]

return data

else:

for i in range(len(data) - 1):

min_index = i

for j in range(i+1, len(data)):

if data[j] > data[min_index]:

min_index = j

data[i], data[min_index] = data[min_index], data[i]

return data

选择排序和冒泡排序还是很相似的,但是选择排序会比冒泡排序少一次交换的过程,但是同样是两层循环,所有时间复杂度也是 O(n^2)

插入排序

插入排序的思想是把一个数据插入到一个有序序列中,从而得到一个新的序列加一的有序序列,可以通过下图来进一步加深理解

a0dfb7fb26ca?utm_campaign

def insert_sort(data, reverse=False):

if not reverse:

for i in range(1, len(data)):

key = data[i]

j = i - 1

while j >= 0:

if data[j] > key:

data[j+1] = data[j]

data[j] = key

j -= 1

return data

else:

for i in range(1, len(data)):

key = data[i]

j = i - 1

while j >= 0:

if data[j] < key:

data[j+1] = data[j]

data[j] = key

j -= 1

return data

由于每次遍历有序序列时,都会有序列中所有的数据做对比,故而时间复杂度为O(n^2)

快速排序

快排的思想为首先任意选取一个数据(通常选用数组的第一个数)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序,之后再递归排序两边的数据。

def quick_sort(data):

if not data:

return data

first = data[0]

left = quick_sort([l for l in data[1:] if l < first])

right = quick_sort([r for r in data[1:] if r >= first])

return left + [first] + right

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python递归函数是指一个函数在其函数体内调用自己的一种方法。它是一种简洁而有力的编程技巧,适用于解决需要重复进行相同或者相似操作的问题。 在Python中,使用递归函数的语法很简单,只需要在函数体内调用自身并提供适当的终止条件即可。递归函数通常包括两个部分:基本情况和递归情况。 基本情况是指函数可以直接得到结果而不需要调用自身的情况。在遇到基本情况时,递归函数就可以停止递归并返回结果,从而避免无限循环。 递归情况是指函数需要调用自身来解决更小规模的问题的情况。在递归情况下,函数将输入参数缩小到更小的规模,然后再次调用自身,直到达到基本情况。 递归函数可以解决很多问题,比如计算斐波那契数列、计算阶乘、二叉树的遍历等。递归函数的运行过程可以形象地表示为一个函数的调用栈。 需要注意的是,递归函数可能存在性能问题。因为每次递归调用都会创建一个新的函数帧,所以递归函数的内存消耗较大。此外,如果递归调用的深度过大,可能会导致堆栈溢出错误。 为了解决这些问题,可以优化递归函数的实现,比如使用尾递归优化、剪枝等技巧。另外,在使用递归函数时,一定要确定递归结束条件,并尽量避免无限递归的情况。 总之,Python递归函数是一种非常有用的编程技巧,可以简化问题的解决过程。但是在使用时需要注意性能和终止条件,避免出现问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值