【经典算法】冒泡排序

这篇具有很好参考价值的文章主要介绍了【经典算法】冒泡排序。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

冒泡排序是Java中非常经典的一种排序方法,可以将多个数字进行升序排序,效率比较高。


一、冒泡排序的基本思想

冒泡排序(Bubble Sorting)的基本思想是: 通过对待排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发现逆序则交换,使值较大的元素逐渐从前移向后部,就象水底下的气泡一样逐渐向上冒。

冒泡排序算法的运作如下:

1、比较两个相邻的数,如果前面的数大于后面的数,则将这两个数交换位置。第一次遍历后,最大的数会被放到数组的最后位置,即array[length - 1]。

2、第二次遍历时跳过最后一个元素,因为该元素通过第一次遍历已经确定是最大值。

3、持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

二、冒泡排序的原理(图解)

冒泡排序的原理是:外层循环遍历整个数组,内层循环对相邻元素进行比较,把最大值选出来交给外层下标,依次进行。

定义的数组int arr[] = {15, 63, 97, 12, 235, 66}

冒泡排序法的基本思路,Java,数据结构与算法,数据结构,排序算法,算法,Powered by 金山文档

第一次循环:

1、首先比较arr[0]和arr[1],即15和63;因为15< 63,因此两个数的位置不变。

[15, 63, 97, 12, 235, 66]

比较和交换对应的代码如下:

if (arr[j] > arr[j + 1]) {
    int temp = arr[j];
    arr[j] = arr[j + 1];
    arr[j + 1] = temp;
}

2、接着比较arr[1]和arr[2],即63和97;因为63 < 97,因此两个数的位置不变,如下

[15, 63, 97, 12, 235, 66]

3、接着比较arr[2]和arr[3],即97和12;因为97 > 12,因此交换两个数的位置,交换完的数组如下:

[15, 63, 12, 97, 235, 66]

4、接着比较arr[3]和arr[4],即97和235;因为97 < 235,因此两个数的位置不变,如下:

[15, 63, 12, 97, 235, 66]

5、最后比较arr[4]和arr[5],即235和66;因为235 > 66,因此交换两个数的位置,交换完的数组如下:

[15, 63, 12, 97, 66, 235]

至此第一次循环结束,由于是相邻两数比较,可以看到第一次循环我们只需要进行5次比较,即:(arr.length - 1) 次。

接着下一轮,不断循环

用具体的例子展示,每次循环需要比较的次数如下:

第一次循环:arr.length - 1 - 0
第二次循环:arr.length - 1 - 1
第三次循环:arr.length - 1 - 2
...

三、时间复杂度

在通常情况下。冒泡排序的比较次数 = (n - 1) + (n - 2) + ... + 2 + 1,即:n * (n - 1) / 2,所以冒泡排序的时间复杂度为:O(n^2)。

四、使用场景

由于冒泡排序的时间复杂度为:O(n^2)。因此,在进行量比较大的排序时,最好不要采用冒泡排序。经过简单的测试,在1000个数字以内的排序,用冒泡排序是可以接受的。1000个随机数使用冒泡排序耗时一般在5毫秒以内,但是当数字个数达到10000个时,耗时会达到100+毫秒,简直是灾难。

五、最优情况

对排序算法熟悉的人应该知道,冒泡排序最优情况的时间复杂度是:O(n),怎么得出来的了?通过上文的代码是无法达到O(n)的,需要对上文的代码进行一点点的优化,优化后的代码如下。

public static void bubbleSort(int[] arr) {
        // 临时变量
        int temp = 0;
        // 标识变量,表示是否进行过交换
        boolean flag = false;
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1 - i; j++) {
                // 如果前面的数比后面的数大,则交换
                if (arr[j] > arr[j + 1]) {
                    flag = true;
                    temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
            System.out.println("第" + (i + 1) + "趟排序后的数组");
            System.out.println(Arrays.toString(arr));
            // 在一趟排序中,一次交换都没有发生过
            if (!flag) {
                break;
            } else {
                // 重置flag, 进行下次判断
                flag = false;
            }
        }
    }

六、完整代码

package com.example.demo;

import java.text.SimpleDateFormat;
import java.util.Arrays;
import java.util.Date;

/**
 * @author Biyu
 * @projectName demo
 * @className: BubbleSort
 * @description //TODO
 * @date: 2023-01-10 22:44
 */
public class BubbleSort {

    public static void main(String[] args) {
        int arr[] = {15, 63, 97, 12, 235, 66};

        Date beginDate = new Date();
        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String beginDateStr = simpleDateFormat.format(beginDate);
        System.out.println("排序前的时间是=" + beginDateStr);

        bubbleSort(arr);

        Date endDate = new Date();
        String endDateStr = simpleDateFormat.format(endDate);
        System.out.println("排序后的时间是=" + endDateStr);
    }

    /**
     * 冒泡排序
     *
     * @param arr
     */
    public static void bubbleSort(int[] arr) {
        // 临时变量
        int temp = 0;
        // 标识变量,表示是否进行过交换
        boolean flag = false;
        for (int i = 0; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - 1 - i; j++) {
                // 如果前面的数比后面的数大,则交换
                if (arr[j] > arr[j + 1]) {
                    flag = true;
                    temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
            System.out.println("第" + (i + 1) + "趟排序后的数组");
            System.out.println(Arrays.toString(arr));
            // 在一趟排序中,一次交换都没有发生过
            if (!flag) {
                break;
            } else {
                // 重置flag, 进行下次判断
                flag = false;
            }
        }
    }
}

运行结果:文章来源地址https://www.toymoban.com/news/detail-795890.html

冒泡排序法的基本思路,Java,数据结构与算法,数据结构,排序算法,算法,Powered by 金山文档

到了这里,关于【经典算法】冒泡排序的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 扎实打牢数据结构算法根基,从此不怕算法面试系列之010 week02 01-01 最简单的排序算法-选择排序法的设计思想

    接下类,我们学习另外一类非常基础的算法,即排序算法。 排序算法是计算机科学领域研究的非常深入的一类算法,排序这个动作本身也是非常重要的, 很多时候面对无需的数据,首先需要做的就是对他们进行排序。 排序算法——目的:让数据有序。 排序算法——种类:种

    2023年04月21日
    浏览(57)
  • 数据结构算法练习 插入排序 冒泡排序

    插入排序 代码如下  package main import \\\"fmt\\\" func main() {     a := []int{4, 5, 6, 1, 3, 2}         b := insert(a)     for i := 0; i len(b); i++ {         fmt.Println(b[i])     } } func insert(a []int) []int {     if len(a) = 1 {                   如果数组长度小于等于1 不用排序直接返回          retur

    2024年02月08日
    浏览(55)
  • 数据结构算法--2 冒泡排序,选择排序,插入排序

    思想就是将相邻元素两两比较,当一个元素大于右侧相邻元素时,交换他们的位置,小于右侧元素时,位置不变,最终序列中的最大元素,像气泡一样,到了最右侧。 这时冒泡排序第一轮结束,数列最右侧元素9的位置可认为是一个有序区,有序区目前有一个元素. 第二轮排序

    2024年02月13日
    浏览(62)
  • 两个基本排序算法【选择排序,冒泡排序】【详解】

    一、前言 二、选择排序 2.1 选择排序(基础版)【必会】 2.2 选择排序(优化版) 三、冒泡排序 3.1 冒泡排序(基础版)【必会】 3.2 冒泡排序(外循环优化版) 3.3 冒泡排序(内循环优化版) 四、总结   排序法主要分为两种: 比较排序 和 非比较排序 。常见的比较排序有

    2024年02月03日
    浏览(31)
  • 【数据结构】排序算法(二)—>冒泡排序、快速排序、归并排序、计数排序

    👀 樊梓慕: 个人主页  🎥 个人专栏: 《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》 🌝 每一个不曾起舞的日子,都是对生命的辜负 目录 前言 1.冒泡排序 2.快速排序 2.1Hoare版 2.2占坑版 2.3前后指针版 2.4三数取中对快速排序的优化 2.5非递归版 3.归

    2024年02月08日
    浏览(50)
  • 【数据结构与算法】冒泡排序算法(BubbleSort)

    目录 1、缘起 2、BubbleSort 算法描述 3、用图示描述 BubbleSort 算法 4、C 语言描述 5、Python 语言描述  6、Java 语言描述  7、总结         冒泡排序算法 是一个非常经典的算法,它是各大网络编程平台上的座上宾,面试官口中的最爱。这个算法就是因其中数字从列表的开始向顶

    2024年02月03日
    浏览(42)
  • [ 数据结构 -- 手撕排序算法第二篇 ] 冒泡排序

    手撕排序算法系列之:冒泡排序。 从本篇文章开始,我会介绍并分析常见的几种排序,大致包括 插入排序 , 冒泡排序 ,希尔排序,选择排序,堆排序,快速排序,归并排序等。 大家可以点击此链接阅读其他排序算法:排序算法_大合集(data-structure_Sort) 本篇主要来手撕冒

    2024年02月11日
    浏览(56)
  • 直接插入排序、希尔排序、直接选择排序、堆排序、冒泡排序——“数据结构与算法”

    各位CSDN的uu们你们好呀,今天小雅兰的内容是数据结构与算法啦,是排序!!!下面,让我们进入七大排序的世界吧!!! 排序:所谓排序,就是使一串记录,按照其中的某个或某些的大小,递增或递减的排列起来的操作。 稳定性:假定在待排序的记录序列中,存在

    2024年02月15日
    浏览(65)
  • 【数据结构】常见排序算法——常见排序介绍、选择排序(直接选择排序、堆排序)交换排序(冒泡排序)

      选择排序是一种简单但不高效的排序算法,其基本思想是从待排序的数据中选择最小(或最大)的元素放到已排序的数据末尾。具体操作步骤如下: (1)找到数据中最小的元素,并把它交换到第一个位置; (2)在剩下未排序的元素中找到最小的元素,并把它交换到已排

    2024年02月04日
    浏览(52)
  • 【数据结构与算法】单链表的排序算法(选择,冒泡,递归)

    目录 选择排序 冒泡排序 快速排序 合并两条链表并排序 选择排序 链表的选择排序思想与数组的排序类似,但是链表需要先找到里面最小或者最大的值,然后将这个值用改链语句进行操作 我们先看这个改链语句的操作(min是笔者打错了应该是max,但是图已经画好了就没有改)

    2024年02月04日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包