排序算法——冒泡排序

排序算法——冒泡排序

大纲目录
排序算法简介

一、基本介绍

  1. 冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发现逆序则交换,使值较大的元素逐渐从前移向后部,就象水底下的气泡一样逐渐向上冒。
  2. 因为排序的过程中,各元素不断接近自己的位置,如果一趟比较下来没有进行过交换,就说明序列有序,因此要在排序过程中设置一个标志flag判断元素是否进行过交换。从而减少不必要的比较。
  3. 前一轮的最终交换位置为本轮的最终截至位置-1

二、冒泡排序图解

在这里插入图片描述

三、源码

/**
 * @author(作者):Liubaoteng
 * @date(创建日期):2022/7/26 20:52
 * 冒泡排序
 * *****************************************************************************
 */
public class BubbleSort {
    public static void main(String[] args) {
//        int arr[]  = {3,44,38,5,47,15,36,26,27,2,46,4,19,50,48};
//        bubblesort2(arr);
//        System.out.println(Arrays.toString(arr));
        int[] arr = new int[80000];
		for(int i =0; i < 80000;i++) {
			arr[i] = (int)(Math.random() * 8000000); //生成一个[0, 8000000) 数
		}
        System.out.println("80000条数据排序开始:");
        long start1 = System.currentTimeMillis();
//        bubblesort1(arr);//9984
        bubblesort2(arr);//9845
        long end1 = System.currentTimeMillis();
        System.out.println("80000条数据排序结束:");
        System.out.println("80000条数据排序耗时:"+(end1-start1));
    }

    //冒泡排序简单版
    public static void bubblesort1(int[] arr){
        int temp = 0;
        for(int i=0;i<=arr.length-1;i++){
            for(int j=0;j<=arr.length-2-i;j++){
                if(arr[j]>arr[j+1]){
                    temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1]=temp;
                }
            }
        }
    }


    /**
     *冒泡排序优化版
     * 1、如果一轮遍历无数字交换,则已排序好
     * 2、前一轮的最终交换位置为本轮的最终截至位置-1
     **/
    public static void bubblesort2(int[] arr){
        int temp = 0;
        Boolean flag = true;
        int boundary = arr.length-2;
        int lastLocation = 0;
        for(int i=0;i<=arr.length-1;i++){
            for(int j=0;j<=boundary;j++){
                if(arr[j]>arr[j+1]){
                    flag = true;
                    temp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1]=temp;
                    lastLocation = j-1;
                }
            }
            boundary = lastLocation;
            if(!flag){
                break;
            }
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值