时间/空间复杂度,基础排序算法(冒泡、选择、快速、插入)

一、时间复杂度、空间复杂度

时间复杂度:用来评估算法运行效率的一个东西,用O()来表示

举例时间复杂度计算:

print(‘Hello World‘)      O(1)
for i in range(n):           #n次循环
     print(‘Hello World‘)    O(n)
for i in range(n):
    for j in range(n):          #两个n嵌套循环
        print(‘Hello World‘)      O(n²)

以下这些代码时间复杂度呢?

print(‘Hello World‘)
print(‘Hello Python‘)          #看着是三个运行,但是也是O(1)
print(‘Hello Algorithm’)        O(1)
for i in range(n):
    print(‘Hello World’)
        for j in range(n):
            print(‘Hello World‘)      O(n²)

下面这个代码的时间复杂度呢?

while n > 1:
    print(n)
    n = n // 2

2^6=64
log2^64=6
所以时间复杂度是:O(log2^n),也可以当做O(logn)

时间复杂度小结:

1.时间复杂度是用来估计算法运行时间的一个式子(单位)。
2.一般来说,时间复杂度高的算法比复杂度低的算法慢。

如何一眼判断时间复杂度?

1.循环减半的过程:O(logn)
2.几次循环就是n的几次方的复杂度

空间复杂度:用来评估算法内存占用大小的一个式子。

采用:空间换时间

二、列表排序

列表排序:将无序列表变为有序列表

输入:无序列表

输出:有序列表

几种常见的排序算法:冒泡排序,选择排序,插入排序,快速排序等

1.冒泡排序

思路:

1.有一个无序列表,比较列表两个相邻的数,如果前边的比后边的大,就交换它们两个

2.对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对,这样最后的元素就是值最大的。

3.重复上面的步骤,除了最后一个

所以我们要写两个for循环:

第一个for循环作用:控制排序的轮数

第二个for循环作用:控制每一轮里的每一个比较

冒泡排序代码如下:

li=[4,1,3,6,7,9,2,5,8]
def Bubble_sort(li):
    for i in range(len(li)-1):
        for j in range(len(li)-1-i):
            if li[j] > li[j+1]:
                li[j], li[j+1] = li[j+1], li[j]
    print(li)
Bubble_sort(li)   #排序结果 [1, 2, 3, 4, 5, 6, 7, 8, 9]

冒泡排序的时间复杂度:O(n²),空间复杂度O(1)

冒泡排序优化:

如果冒泡排序中执行一趟而没有交换,则列表已经是有序状态,可以直接结束算法。

2.选择排序 

思路:

1.一趟遍历记录最小的数,放到第一个位置。

2.再一趟遍历记录剩余列表中最小的数,继续放置

可以理解为:取列表索引为0的值,和后面位置的元素比较,索引为0的值大于其他位置的值就调换位置。索引0的值和所有元素比较完了,再索引1的值和后面元素依次比较,索引1的值大于其他位置的值就调换位置,以此类推,从小到大排序。

选择排序代码示例:

li=[4,3,6,1,7,9,2,5,8]

def select_sort(li):
    for i in range(len(li)):
        minLoc = i   ###i = 0
        for j in range(i+1, len(li)):
            if li[j] < li[minLoc]:
                li[j], li[minLoc] = li[minLoc], li[j]
    print(li)
select_sort(li)   #结果[1, 2, 3, 4, 5, 6, 7, 8, 9]

选择排序的时间复杂度:O(n²),空间复杂度O(1)

3.插入排序

思路:类似于斗地主插牌

1.列表被分为有序区和无序区两个部分,最初有序区只有一个元素,假如抽取第一个元素

2.每次从无序区选择一个元素,插入到有序区的位置,和有序区的值一一比较,直到无序区变空

插入排序代码示例:

li=[4,3,6,1,7,9,2,5,8]
def insert_sort(li):
    for i in range(1, len(li)):
        tmp = li[i]
        j = i - 1
        while j >=0 and li[j] > tmp:
            li[j+1] = li[j]
            j = j - 1
        li[j+1] = tmp
    print(li)
insert_sort(li)   #结果  [1, 2, 3, 4, 5, 6, 7, 8, 9]

插入排序时间复杂度:O(n²),空间复杂度O(1)

4.快速排序

好写的排序算法里最快的 ,快的排序算法里最好写的(写法比之前的几种复杂一点)

思路:

1.从数列中取出一个元素(一般取第一个元素),称为"基准"

2.写一个函数重新排序数列,所有元素比基准小的都放在基准左边,所有元素比基准大的都放在右边,相同的数到同一边。在这个分区退出之后,该基准就处于数列的中间位置。

3.再写一个函数,使用递归把小于基准值元素的子数列和大于基准值元素的子数列排序。递归的最底部情形,是数列的大小是零或一,也就是永远都已经被排序好了。虽然一直递归下去,但是这个算法总会退出,因为在每次的迭代中,它至少会把一个元素摆到它最后的位置去。

快速排序关键点:1.整理,2.递归

快速排序代码示例:

li=[4,3,6,1,7,9,2,5,8]
#第一个函数,根据基准分区
def partition(li, left, right):
    tmp = li[left]
    while left < right:
        while left < right and li[right] >= tmp:
            right = right - 1
        li[left] = li[right]
        while left < right and li[left] <= tmp:
            left = left + 1
        li[right] = li[left]
    li[left] = tmp

    return left
#第二个函数使用迭代
def quick_sort(li, left, right):
    if left < right:
        mid = partition(li, left, right)
        quick_sort(li, left, mid-1)
        quick_sort(li, mid+1, right)
        print(li)
quick_sort(li, 0, len(li)-1)     #结果:[1, 2, 3, 4, 5, 6, 7, 8, 9]

快速排序时间复杂度:O(nlogn),空间复杂度:O(logn)

未完。。。。

原文地址:https://www.cnblogs.com/wangcuican/p/12094060.html

时间: 2024-08-03 23:48:53

时间/空间复杂度,基础排序算法(冒泡、选择、快速、插入)的相关文章

基础排序算法—冒泡,插入,选择

前言 冒泡,插入,选择这三种基础的排序算法,比较简单效率不高,工作中一般不会使用,但是当做算法来研究还是能了解一些知识的,本文以<数据结构与算法之美>为基础,详细解析一下. 正文 首先要引入几个概念 稳定性 如果待排序数组中有相同的元素,排序过后它们的相对顺序不发生变化. 比如 2,9,3,4,8,3 排序过后为2, 3 , 3, 4, 8, 9 这两个3的相对顺序不变.这样就是具有稳定性. 稳定性可以保证复杂数据结构排序时的相对有序性. 比如我们要对一笔订单先按金额排列,金额相同的再按时间排

排序算法之选择、插入、冒泡、快速

三个类: AbstractSortService : package cn.zhi.sort; public abstract class AbstractSortService { public void swap(int[] array, int i, int j) { if (i != j) { int temp = array[i]; array[i] = array[j]; array[j] = temp; } } public void print(int[] arr) { for

排序算法-冒泡、插入、归并、希尔、快速、选择--代码总结

冒泡排序代码: #include <iostream> #include <string> using namespace std; template<class ItemType> void bubbleSort(ItemType theArray[], int n) { bool sorted = false; // False when swaps occur int pass = 1; while (!sorted && (pass < n

九大基础排序算法总结

九大基础排序算法小结 一直想做份总结,总是抽不出时间,趁着周末闲着直接用了一整天做一份,一些内容参考了网上的一些博主的总结,还有网络上的一些图片. 好了,接下来就看看内容吧! 排序算法: 排序方法 时间复杂度 空间复杂度 稳定性 选用情况 平均情况 最坏情况 最好情况 Insertion Sort O(n^2) O(n^2) O(n) O(1) 稳定 n较小时 Selection Sort O(n^2) O(n^2) O(n^2) O(1) 不稳定 n较小时 Bubble Sort O(n^2)

基础排序算法

七个基础排序算法(均为内部排序): 直接插入排序 希尔排序 冒泡排序 简单选择排序 快速排序 堆排序 二路归并排序 排序算法稳定性:经过排序后,具有相同关键码的元素之间的相对次序保持不变,则称该排序方法是稳定的;否则不稳定. 直接插入排序: void InsertSort(int a[],int n){ // index start at 1, a[0] is temp one int i,j; for(i=2;i<=n;i++){ if(a[i]<a[i-1]){ a[0]=a[i]; a[

基础排序算法 c#

算法知识欠缺,学习几种基础排序算法,1. 选择排序  2.冒泡排序 3.插入排序 以升序为例,程序中凡是 两个值的比较前者大于后者,则调换位置 1. 选择排序 最容易想到的排序算法,但却不知道这种叫做选择排序法 1 /// <summary> 2 /// 选择排序 3 /// </summary> 4 /// <param name="sourceValues"></param> 5 /// <returns></ret

排序算法之选择排序

一. 算法描述 选择排序:在一个长度为N的无序数组中,在第一趟遍历N个数据,找出其中最小的数值与第一个元素交换,第二趟遍历剩下的N-1个数据,找出其中最小的数值与第二个元素交换......第N-1趟遍历剩下的2个数据,找出其中最小的数值与第N-1个元素交换,至此选择排序完成. 二. 算法分析 平均时间复杂度:O(n2) 空间复杂度:O(1)  (用于交换和记录索引) 稳定性:不稳定 (比如序列[5, 5, 3]第一趟就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面) 三. 算法实现

php四种基础排序算法的运行时间比较!

/** * php四种基础排序算法的运行时间比较 * @authors Jesse (jesse152@163.com) * @date 2016-08-11 07:12:14 */ //冒泡排序法 function bubbleSort($array){ $temp = 0; for($i = 0;$i < count($array) -1;$i++){ for($j = 0;$j < count($array) - 1 -$i;$j++){ if($array[$j] > $arra

php四种基础排序算法的运行时间比较

/** * php四种基础排序算法的运行时间比较 * @authors Jesse (jesse152@163.com) * @date 2016-08-11 07:12:14 */ //冒泡排序法 function bubbleSort($array){ $temp = 0; for($i = 0;$i < count($array) -1;$i++){ for($j = 0;$j < count($array) - 1 -$i;$j++){ if($array[$j] > $arra

基础排序算法详解与优化

常见的基础排序有选择排序.冒泡排序和插入排序.众所周知,他们的时间复杂度是 O(n\*n). 但是,现在要重新认识一下基础排序算法,尤其是“插入排序”:在近乎有序的情况下,插入排序的时间复杂度可以降低到 O(n)的程度. 因此,在处理系 原文地址:https://www.cnblogs.com/wdyff/p/9749837.html