冒泡排序

简介

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

## 思路
- 比较相邻的元素。如果第一个比第二个大(升序),就交换他们两个。
- 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。
- 针对所有的元素重复以上的步骤,除了最后一个。
- 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。


## 实现
```python
def bubble_sort(lst):
# j表示每次遍历需要比较的次数,是逐渐减小的
for j in range(len(lst)-1, 0, -1):
for i in range(j):
if lst[i] > lst[i+1]:
lst[i], lst[i+1] = lst[i+1], lst[i]


<br>
## 演示
![](https://img2018.cnblogs.com/blog/1542801/201904/1542801-20190401184451030-1862868144.gif) <br>
## 时间复杂度
- 最优时间复杂度:O(n) (表示遍历一次发现没有任何可以交换的元素,排序结束。)
- 最坏时间复杂度:O(n2)
- 稳定性:稳定 <br>
# 选择排序 ## 简介
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。 <br>
## 思路
选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。 <br>
## 实现
```python
def selection_sort(lst):
n = len(lst)
for i in range(n-1):
# 记录最小位置
min_index = i
# 每循环一次,找到最小值的索引
for j in range(i+1, n):
# 如果比最小值小,就把j置为min_index
if lst[j] < lst[min_index]:
min_index = j
# 不相等时才交换
if min_index != i:
lst[i], lst[min_index] = lst[min_index], lst[i]

## 演示
![](https://img2018.cnblogs.com/blog/1542801/201904/1542801-20190401184517027-423618286.gif)


## 时间复杂度
- 最优时间复杂度:O(n2)
- 最坏时间复杂度:O(n2)
- 稳定性:不稳定(考虑升序每次选择最大的情况)


# 插入排序

简介

插入排序(英语:Insertion Sort)是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

实现

def insert_sort(lst):
for i in range(1, len(lst)):
# 从第i个元素开始向前比较,前面的已经是有序数列
for j in range(i, 0, -1):
# 逐个比较,直到待排序元素处于正确的位置上
if lst[j] < lst[j-1]:
lst[j], lst[j-1] = lst[j-1], lst[j]

## 演示
![](https://img2018.cnblogs.com/blog/1542801/201904/1542801-20190403222607920-1590609728.gif)

时间复杂度

  • 最有时间复杂度:O(n) (序列已经是升序时)
  • 最坏时间复杂度:O(n^2)
  • 稳定性:稳定

# 快速排序
## 简介
快速排序是一种常见的排序算法,比选择排序快得多。快速排序使用了分而治之和递归的思想

思路

  • 选择一个基准值
  • 将小于和大于基准值的元素各放在一个列表里,得到两个子列表
  • 对两个子列表分别进行快速排序
  • 当列表元素等于0或者1时,达到递归出口

实现

def quick_sort(lst):
if len(lst) < 2:
return lst # 基线条件,0,1个元素的列表不需要排序
else:
pivot = lst[0] # 基准元素
less = [i for i in lst if i < pivot] # 小于基准元素的元素组成的列表
greater = [i for i in lst if i > pivot] # 大于基准元素的元素组成的列表
return quick_sort(less) + [pivot] + quick_sort(greater)

## 演示

## 时间复杂度
- 最优时间复杂度:O(nlogn)
- 最坏时间复杂度:O(n2)
- 稳定性:不稳定

补充:关于时间复杂度,递归调用O(logn)次,每次比较分区O(n),合起来就是O(nlogn)

# 归并排序
## 简介
归并排序是采用分治法的一个非常典型的应用。归并排序的思想就是先递归分解数组,再合并数组。


## 思路
- 将列表分成两个列表
- 分别对列表进行归并排序
- 比较两个数组的最前面的数,谁小先取谁

实现

def merge_sort(lst):
if len(lst) <= 1:
return lst
# 二分分解
num = len(lst)//2
left = merge_sort(lst[:num])
right = merge_sort(lst[num:]) # 合并
return merge(left, right) def merge(left, right):
"""将两个有序数组left[]和right[]合并成一个大的数组""" # left 和 right的下标指针
l, r = 0, 0
result = []
while l < len(left) and r < len(right):
if left[l] < right[r]:
result.append(left[l])
l += 1
else:
result.append(right[r])
r += 1 # 循环结束后,一个数组为空,另一个数组还有值,要把剩余的添加到result里
result += left[l:]
result += right[r:]
return result

## 演示
![](https://img2018.cnblogs.com/blog/1542801/201904/1542801-20190403222743143-183917297.gif)


## 时间复杂度
- 最优时间复杂度:O(nlogn)
- 最坏时间复杂度:O(nlogn)
- 稳定性:稳定

补充:关于时间复杂度,递归调用O(logn)次,每次比较O(n),合起来就是O(nlogn)

## 常见算法比较
![](https://img2018.cnblogs.com/blog/1542801/201904/1542801-20190403222246930-779167120.png)

常见排序算法之python实现的更多相关文章

  1. 常见排序算法-Python实现

    常见排序算法-Python实现 python 排序 算法 1.二分法     python    32行 right = length-  :  ]   ):  test_list = [,,,,,, ...

  2. python常见排序算法解析

    python——常见排序算法解析   算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法 ...

  3. python——常见排序算法解析

    算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法,分别是冒泡排序,插入排序,选择排序, ...

  4. python 的常见排序算法实现

    python 的常见排序算法实现 参考以下链接:https://www.cnblogs.com/shiluoliming/p/6740585.html 算法(Algorithm)是指解题方案的准确而完 ...

  5. 常用排序算法的python实现和性能分析

    常用排序算法的python实现和性能分析 一年一度的换工作高峰又到了,HR大概每天都塞几份简历过来,基本上一天安排两个面试的话,当天就只能加班干活了.趁着面试别人的机会,自己也把一些基础算法和一些面试 ...

  6. 十大经典排序算法的python实现

    十种常见排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序.包括:冒泡排序.选择排序.归并排序.快速 ...

  7. 常见排序算法(附java代码)

    常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...

  8. 八大排序算法的 Python 实现

    转载: 八大排序算法的 Python 实现 本文用Python实现了插入排序.希尔排序.冒泡排序.快速排序.直接选择排序.堆排序.归并排序.基数排序. 1.插入排序 描述 插入排序的基本操作就是将一个 ...

  9. JS常见排序算法

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. 【bfs】仙岛求药

    [题目描述] 少年李逍遥的婶婶病了,王小虎介绍他去一趟仙灵岛,向仙女姐姐要仙丹救婶婶.叛逆但孝顺的李逍遥闯进了仙灵岛,克服了千险万难来到岛的中心,发现仙药摆在了迷阵的深处.迷阵由M×N个方格组成,有的 ...

  2. 部署KVM

    1.安装前准备1)服务器或者PC的CPU能支持VT技术2)虚拟机中安装KVM要勾选:处理器:虚拟化Intel VT-x/EPT或AMD-V/RVI(V)[root@localhost ~]# cat ...

  3. loj6157 A ^ BProblem (并查集)

    设s[x][i]表示从根到x的异或和在第i位上的值(0/1),(a,b,i)表示a到b的异或和在第i位上的值那么就有(a,b,i)=(s[a][i]^s[b][i]^s[lca][i]^s[lca][ ...

  4. eclipse 设置

    修改工作空间默认编码:Window --> Preferences --> General --> Workspace --> Text file encoding --> ...

  5. 洛谷P3975 弦论

    题意:求一个串的字典序第k小的子串/本质不同第k小的子串. 解:一开始我的想法是在后缀树上找,但是不知道后缀树上的边对应的是哪些字符... 然而可以不用fail树转移,用转移边转移即可. 先建一个后缀 ...

  6. A1066. Root of AVL Tree

    An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child sub ...

  7. 【洛谷P4462】异或序列

    题目大意:给定一个长度为 N 的序列,有 M 组询问,每组询问查询区间 [l,r] 内异或和等于给定常数 K 的区间组数. 题解:对于异或和问题,一般先进行前缀和处理,转化为两个点的的关系.因此,经过 ...

  8. bzoj3238 差异

    题目链接 思路 观察题目中的式子,可以发现前两项是定值.所以只需要求出最后一项就行了. 然后题目就转化为了求字符串中所有后缀的\(lcp\)长度之和. 可以想到用后缀数组.在后缀数组上两个后缀的\(l ...

  9. ImageMagick 笔记: 索引颜色(index color)、锁定图层,透明 png 转 gif (保持清晰度)

    今天在处理一张 png 透明背景的图片,大小: 16KB, 尺寸: 400 x 300,用到一段代码,也许对以后有用. /** 带透明背景和阴影的png图片, 转换成 gif, [索引色] + [锁住 ...

  10. Django(一)自定义web框架

    https://www.cnblogs.com/yuanchenqi/articles/6083427.htm 一 什么是web框架 框架,即framework, 特指为解决一个开放性问题而设计的具有 ...