IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> java/python/C++【冒泡排序】 -> 正文阅读

[数据结构与算法]java/python/C++【冒泡排序】

原理

冒泡排序(Bubble Sort)是基于交换的排序,每次遍历需要排序的元素,依次比较两个相邻元素的大小,如果前一个元素大于后一个元素则两者交换,保证最后一个数字一定 是最大的(假设按照从小到大排序),即最后一个元素已经排好序,下一轮只需要保证前面n-1个元素的顺序即可。
之所以称为冒泡,是因为最大/最小的数,每一次都往后面冒,就像 是水里面的起泡一样。

步骤

假设从小到大 排序,步骤如下:

1、从头开始,比较相邻的两个数,如果第一个数比第二个数大,那么交换它们的位置;
2、继续 开始比较与其后面相邻的数,直到一轮结束后,最后一个元素的位置已经确定好;
3、除了最后一个元素以外,前面的所有未排好序的元素重复前面两个步骤;
4、重复前面1~3步骤,直到所有元素都已经排好序。

交换逻辑

例如,我们需要对数组 [98,40,34] 进行从小到大排序,每一次都需要将数组最大的移动到数组尾部。那么排序的过程如下所示:
在这里插入图片描述
在这里插入图片描述
从上面中可以看出,总共是3个数,冒泡2次即可。

代码实现

java实现

public class BubbleSort {

    public static void main(String[ ] args) {
    int[]nums = new int[]{98,90,34,56,21};
    printf(nums);
    bubbleSort(new int[]{98,90,34,56,21});
}

    public static void printf(int[] nums) {
        for (int num : nums) {
            System.out.print(num + " ");
        }
        System.out.println("");
    }

    public static void bubbleSort(int[] nums) {
      int size = nums.length;
      // 每轮针对前面(size-i)个数进行排序
      for (int i = 0; i < size - 1; i++) {
        System.out.println("第" + (i + 1) + "轮交换开始");
        // 每一轮排序,从第 0 个元素,到 size-1-i 个元素
        for (int j = 0; j < size - 1 - i; j++) {
          // 对比相邻的两个元素
          if (nums[j] > nums[j + 1]) {
            // 元素交换。使得大的元素在后面
            int temp = nums[j+1];
            nums[j + 1] = nums[j];
            nums[j] = temp;
          }
          printf(nums);
        }
      }
    }
  }

python代码实现

class Solution:
    def printNums(self,nums):
        for i in range(len(nums)):
            print("%d" % nums[i],end=" ")
        print("")
    def bubbleSort(self,nums):
        size=len(nums)
        #每轮针对前面(size-i)个数进行排序
        for i in range(size):
            print("第",(i+1),"轮交换开始")
            for j in range(0,size-1-i):
                if nums[j]>nums[j+1]:
                    nums[j],nums[j+1]=nums[j+1],nums[j]
            self.printNums(nums)
    
if __name__=='__main__':
    solution=Solution()
    nums=[98, 90, 34, 56, 21]
    solution.printNums(nums)
    solution.bubbleSort(nums)

c++代码实现

#include <iostream>
using namespace std;

void bubbleSort(int nums[],int size);
void printf(int nums[],int size);

int main() {
    int nums[] = {98,90,34,56,21};
    int size =  sizeof(nums)/sizeof(nums[0]);
    bubbleSort(nums,size);
    return 0;
}

void bubbleSort(int nums[],int size) {
  // 每轮针对前面(size-i)个数进行排序
  for (int i = 0; i < size - 1; i++) {
    cout<<"第" <<  (i + 1) << "轮交换开始" <<endl;
    // 每一轮排序,从第 0 个元素,到 size-1-i 个元素
    for (int j = 0; j < size - 1 - i; j++) {
      // 对比相邻的两个元素
      if (nums[j] > nums[j + 1]) {
        // 元素交换。使得大的元素在后面
        int temp = nums[j + 1];
        nums[j + 1] = nums[j];
        nums[j] = temp;
      }
      printf(nums,size);
    }
  }
}

void printf(int nums[],int size){
    for (int i = 0; i < size; i++) {
        cout<<nums[i]<<" ";
    }
    cout<<endl;
}

时间复杂度与空间复杂度

从上面的代码来看,两层 for 循环嵌套,假设数组的大小为 n,那么第一轮冒泡需要比较 n-1 次,第二轮由于最后一个已经排好,需要比较 n-2 次,依次类推下一轮比较 n-3,n-4 … 直到最后只需要比较第一个元素和最后一个元素,只有 1 次比较,所以比较次数之和为:在这里插入图片描述
上面计算时间复杂度是 O(n^2 ),时间复杂度取系数最高的项即可,当然这是最坏情况下的时间复杂度。如果这个数组已经排好序了,我们在每一轮冒泡的时候,都增加一个标识,表示是否有交换,如果没有交换,说明数组顺序已经排好,排序提前结束。这样一来,时间复杂度就是 O(n) 了,因为只遍历了第一轮的 n 个数。

但是并非所有情况下的排序都这么一帆风顺,除了最好和最坏的情况,还有一些中间情况,平均时间复杂度仍为 O(n^2)

空间复杂度由于只使用了一个变量 temp,没有借助其他的变量,所以空间复杂度为 O(1)。

由于冒泡排序只会交换相邻的元素,它不会出现两个相等的元素,后面的元素被交换到前面去的情况,所以冒泡排序是稳定的。

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-03 16:39:43  更:2022-03-03 16:41:01 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 1:49:30-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码