博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【排序算法】- 冒泡排序
阅读量:4146 次
发布时间:2019-05-25

本文共 2030 字,大约阅读时间需要 6 分钟。

文章目录

1 基本介绍

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

优化:
因为排序的过程中,各元素不断接近自己的位置,如果一趟比较下来没有进行过交换,就说明序列有序,因此要在排序过程中设置一个标志flag判断元素是否进行过交换。从而减少不必要的比较。(这里说的优化,可以在冒泡排序写好后,在进行)

2 演示冒泡过程的例子(图解)

在这里插入图片描述

小结上面的图解过程:
(1) 一共进行数组的大小-1次大的循环
(2) 每一趟排序的次数在逐渐的减少
(3) 如果我们发现在某趟排序中,没有发生一次交换,可以提前结束冒泡排序。这个就是优化

3 冒泡排序应用实例

代码实现:

package com.sukang.sort;import java.text.SimpleDateFormat;import java.util.Arrays;import java.util.Date;/** * @description: * @author: sukang * @date: 2020-07-07 9:42 */public class BubbleSort {    public static void main(String[] args) {        //创建要给80000个的随机的数组        int[] arr = new int[80000];        for (int i = 0; i < 80000; i++) {            arr[i] = (int)(Math.random()*8000000);//生成一个[0,8000000)数        }        //没排序之前数组遍历        System.out.println("排序前的数组" + Arrays.toString(arr));        Date data1=new Date();        SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-ddHH:mm:ss");        String date1Str = simpleDateFormat.format(data1);        System.out.println("排序前的时间是="+date1Str);        bubbleSort(arr);        Date data2 = new Date();        String date2Str = simpleDateFormat.format(data2);        System.out.println("排序后的时间是="+date2Str);        //排序之后数组遍历        System.out.println("排序后的数组" + Arrays.toString(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;                }            }            if(!flag){ // 在一趟排序中,一次交换都没有发生过                break;            }else{                flag = false; // 重置flag!!!, 进行下次判断            }        }    }}

在这里插入图片描述

转载地址:http://wonti.baihongyu.com/

你可能感兴趣的文章
VS2012快捷键大全
查看>>
VS2012入门图文教程——第一个程序Hello World
查看>>
UML类图——学设计模式前必备知识
查看>>
C#接口-简单示例
查看>>
SQL Server 远程过程调用失败——解决方法
查看>>
第一节 登录界面
查看>>
第二节 页面跳转
查看>>
第三节 布局
查看>>
Genymotion运行问题:Unable to connect to your virtual device
查看>>
android 小结1(诚迈时期)
查看>>
在虚拟机以及pc机上安装ubuntu 9.10_x86_64系统搭建android开发环境
查看>>
c++ boost 文件读取写入 逗号隔开的字符串
查看>>
系统应用程序导入Eclipse
查看>>
eclipse 调试framework
查看>>
拨打电话的流程
查看>>
仿htc布局
查看>>
Android LockScreen
查看>>
Android开发之手机铃声代码实现
查看>>
JNI技术与Android应用
查看>>
Android NDK开发轻松入门
查看>>