排序——冒泡排序

简介: 排序——冒泡排序

冒泡排序

基本思想

  • 依次比较相临两个数据元素的大小,若逆序则交换两个数据元素,否则不交换。
  • 当完成一趟交换以后,最大的元素将会出现在数据序列的最后一个位置。
  • 重复以上过程,直到待排序序列中没有逆序为止。
每趟结束时,不仅能挤出一个最大值到最后面位置,还能同时部分理顺其他元素;
       **一旦下趟没有交换,还可提前结束排序**

算法实现

c++代码实现

// 原始冒泡排序
void bubblf_sort(SqList &L){
    // 从大到小有序
    for(i = 1; i <= L.length; ++i)
        for(j = 1; j <= L.length - 1; j++){
            if(L.r[j + 1].key < L.r[j].key){
                temp = L.r[j + 1];
                L.r[j + 1] = L.r[j];
                L.r[j] = temp;
            }

        }
}

// 改进后的算法
void bubblf_sort(SqList &L){
    for(i = 1, change = true; i <= L.length - 1 && change; i++){
        change = false;
        for(j = 1; j < L.length - i; ++i)
            if(L.r[j + 1].key < L.r[j].key){
                temp = L.r[j];
                L.r[j] = L.r[j + 1];
                L.r[j + 1] = temp;
                change = true;
            }
    }
}

python代码实现

'''冒泡排序-BubbleSort'''
def bubble_sort(alist):
    for j in range(len(alist)-1,0,-1):
        # j表示每次遍历需要比较的次数,是逐渐减小的
        for i in range(j):
            if alist[i] > alist[i+1]:
                alist[i], alist[i+1] = alist[i+1], alist[i]

l = [54, 45, 32, 34, 56, 90]
bubble_sort(l)

print(l)
[32, 34, 45, 54, 56, 90]

算法分析

  • 时间复杂度为 O(n^2)

    • 最好情况下: 只需 1趟排序,比较次数为 n-1,不移动
    • 最坏情况下:需 n-1趟排序,第i趟比较n-i次,移动3(n-i)
  • 空间复杂度为 O(1)
  • 是一种稳定的排序方法
目录
相关文章
|
11天前
|
算法 搜索推荐
排序——选择排序
排序——选择排序
23 0
|
11天前
|
搜索推荐 算法 Shell
排序——插入排序
排序——插入排序
18 0
|
7月前
|
算法 搜索推荐 索引
排序篇(二)----选择排序
排序篇(二)----选择排序
15 0
|
7月前
|
存储 搜索推荐 测试技术
排序篇(一)----插入排序
排序篇(一)----插入排序
23 0
|
10月前
|
算法 搜索推荐
排序——冒泡排序
这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端(升序或降序排列),就如同碳酸饮料中二氧化碳的气泡最终会上浮到顶端一样,故名“冒泡排序”。
|
11月前
|
搜索推荐
排序(2)之选择排序
继插入排序后,今天小编就给大家另一个模块,选择排序的学习,那么话不多说,我们直接进入正题。
86 0
|
11月前
|
存储 搜索推荐 测试技术
排序(1)之插入排序
从今天小编就开始给大家介绍排序的内容,对于排序内容我们一共分,插入,选择,交换,归并这几个大类,那么今天小编给大家带来的就是插入排序
72 0
|
索引
掌握常见的几种排序-选择排序
选择排序是一种简单的排序,时间复杂度是O(n^2),在未排序的数组中找到最小的那个数字,然后将其放到起始位置,从剩下未排序的数据中继续寻找最小的元素,将其放到已排序的末尾,以此类推,直到所有元素排序结束为止。
掌握常见的几种排序-选择排序
|
搜索推荐 算法 Java
排序:冒泡排序(算法)
冒泡排序(Bubble Sort),是一种计算机科学领域的较简单的排序算法。 这个算法的名字由来是因为越大的元素会经由交换慢慢“浮”到数列的顶端,故名。
201 0
排序:冒泡排序(算法)
|
算法
排序——快速排序
排序——快速排序
97 0
排序——快速排序