排序算法-冒泡排序

一、冒泡排序

一种简单的排序算法,它重复地遍历待排序的数列,比较相邻的两个元素并按照升序或降序交换它们的位置,从而将最大或最小的元素逐渐"浮"到数组的顶端或底端。

按照冒泡排序的思想,我们要把相邻的元素两两比较,当一个元素大于右侧相邻元素时,交换它们的位置;当一个元素小于或等于右侧相邻元素时,位置不变。过程如下:

冒泡排序是一种稳定排序,值相等的元素并不会打乱原本的顺序。由于该排序算法的每一轮都要遍历所有元素,有n个数,总共遍历(n-1)轮,所以平均时间复杂度是O (n2)。

(1) 基本-冒泡排序

python 复制代码
def bubbleSort(ll):
    #外层循环(轮数)
    for i in range(len(ll)-1):
        #内层循环(次数)
        for j in range(len(ll)-i-1):
            #判断两两比较
            if ll[j]>ll[j+1]:
                #第一个>第二个,则交换
                 ll[j],ll[j + 1] = ll[j + 1],ll[j]


if __name__ == '__main__':
    ll=[5,8,6,3,9,2,1,7]
    print('排序前:')
    print(ll)
    bubbleSort(ll)
    print('排序后:')
    print(ll)

当排序算法分别执行到第6轮、第7轮时,数列状态如下:

很明显,经过第6轮排序后,整个数列已经是有序了,可是排序算法仍然兢兢业业地继续执行了第7轮排序。

(2) 优化-冒泡排序

python 复制代码
def bubbleSort2(ll):
    #外层循环(轮数)
    for i in range(len(ll)-1):
        #标识:有序
        flag=True
        #内层循环(次数)
        for j in range(len(ll)-i-1):
            #判断两两比较
            if ll[j]>ll[j+1]:
                #第一个>第二个,则交换
                ll[j],ll[j + 1] = ll[j + 1],ll[j]
                #还是无序,进行比较交换
                flag=False
        #数列有序,就直接退出循环
        if flag:
            break

(3) 优化-双向冒泡排序

python 复制代码
def bubbleSort3(ll):
    #外层循环(轮数)
    for i in range(len(ll)//2):
        #标识:有序
        flag=True
        # 奇数轮,从左向右比较和交换
        #内层循环(次数)
        for j in range(i,len(ll)-i-1):
            #判断两两比较
            if ll[j]>ll[j+1]:
                #第一个>第二个,则交换
                ll[j],ll[j + 1] = ll[j + 1],ll[j]
                #还是无序,进行比较交换
                flag=False
        #数列有序,就直接退出循环
        if flag:
            break

        # 偶数轮之前,重新标记为true
        # 标识:有序
        flag = True
        # 偶数轮,从右向左比较和交换
        # 内层循环(次数)
        for j in range(len(ll) - i - 1,i,-1):
            # 判断两两比较
            if ll[j] < ll[j - 1]:
                # 第一个>第二个,则交换
                ll[j], ll[j -1] = ll[j - 1], ll[j]
                # 还是无序,进行比较交换
                flag = False
        # 数列有序,就直接退出循环
        if flag:
            break

很明显,这个排序的优点是能够在特定条件下,减少排序的回合数;而缺点也很明显,就是代码量几乎增加了1倍。

相关推荐
写个博客7 分钟前
暑假算法日记第一天
算法
绿皮的猪猪侠9 分钟前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988941 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼1 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield2 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦2 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl2 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder2 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
hqxstudying2 小时前
Java创建型模式---单例模式
java·数据结构·设计模式·代码规范
挺菜的3 小时前
【算法刷题记录(简单题)002】字符串字符匹配(java代码实现)
java·开发语言·算法