线性排序算法(1)

简介: 排序选择排序(适用于线性排序)思路,2层遍历第一步:选择最小的元素,与第一个元素交换。第二步:从第二个元素到最后一个元素,选择最小元素,与第二元素交换完成前两步,第1第2元素已经排好序。
排序

选择排序(适用于线性排序)

思路,2层遍历

  1. 第一步:选择最小的元素,与第一个元素交换。
  2. 第二步:从第二个元素到最后一个元素,选择最小元素,与第二元素交换
  3. 完成前两步,第1第2元素已经排好序。继续遍历。

算法复杂度 O(n^2)

def SelectionSort(a):
    for i in range(len(a)):
        tmp_min = a[i]
        index = i
        for j in range(i,len(a)):
            if a[j]<tmp_min:
                index = j
                tmp_min = a[j]
        tmp = a[i]
        a[i] = a[index]
        a[index] = tmp

插入排序(适用于线性排序)

思路,2层遍历

  1. 第一步:第二元素向前遍历,如果第一个元素比自己大,与第一个元素交换位置
  2. 第二步:从第三个元素到最后一个元素,向前遍历,如果前一个元素比自己大,就交换位置;
  3. 遍历过程中,如果发现前一个元素比自己小,结束遍历。

由于在遍历过程中,当出现前一个元素小于当前元素,提前结束比对,比选择排序算法的比对次数少。

算法复杂度 O(n^2)

def swap(a,i,j):
    tmp  = a[i]
    a[i] = a[j]
    a[j] = tmp
def InsertionSort(a):
    for i in range(1,len(a)):
        for j in range(i,0,-1):
            if(a[j-1]>a[j]):
                swap(a,j-1,j)
            else:
                break

用赋值替换swap,对InsertionSort优化

def InsertionSortCopy(a):
    for i in range(1,len(a)):
        for j in range(i,0,-1):
            tmp = a[j]
            if(a[j-1]>tmp):
                a[j] = a[j-1]
            else:
                a[j] = tmp
目录
相关文章
|
2月前
|
机器学习/深度学习 自然语言处理 算法
【模式识别】探秘判别奥秘:Fisher线性判别算法的解密与实战
【模式识别】探秘判别奥秘:Fisher线性判别算法的解密与实战
118 0
|
8月前
|
算法 安全 量子技术
【Python】蒙特卡洛模拟 | PRNG 伪随机数发生器 | 马特赛特旋转算法 | LCG 线性同余算法 | Python Random 模块
【Python】蒙特卡洛模拟 | PRNG 伪随机数发生器 | 马特赛特旋转算法 | LCG 线性同余算法 | Python Random 模块
171 0
|
6天前
|
算法 Java 机器人
Java数据结构与算法:查找算法之线性查找
Java数据结构与算法:查找算法之线性查找
|
26天前
|
存储 算法 NoSQL
数据结构和算法——哈希查找冲突处理方法(开放地址法-线性探测、平方探测、双散列探测、再散列,分离链接法)
数据结构和算法——哈希查找冲突处理方法(开放地址法-线性探测、平方探测、双散列探测、再散列,分离链接法)
32 1
|
9天前
|
存储 算法 Java
Java数据结构与算法:线性数据结构之数组
Java数据结构与算法:线性数据结构之数组
|
12天前
|
存储 算法 Java
Java数据结构与算法:线性数据结构之链表
Java数据结构与算法:线性数据结构之链表
|
12天前
|
算法 Java 编译器
Java数据结构与算法:线性数据结构之栈
Java数据结构与算法:线性数据结构之栈
|
2月前
|
存储 算法 Java
【数据结构查找算法篇】----线性查找【实战项目】
【数据结构查找算法篇】----线性查找【实战项目】
41 5
|
2月前
|
算法 搜索推荐 程序员
C++标准库算法指南:从线性到复杂度 — 选择最佳工具
C++标准库算法指南:从线性到复杂度 — 选择最佳工具
63 0
|
2月前
|
机器学习/深度学习 存储
【Matlab智能算法】极限学习机-遗传算法(ELM-GA)函数极值寻优——非线性函数求极值
【Matlab智能算法】极限学习机-遗传算法(ELM-GA)函数极值寻优——非线性函数求极值