几大经典排序算法

经典排序算法目录

第一章 排序算法之冒泡排序



前言

非原创,参考自《尚硅谷》韩顺平老师和其他博主。
想要提高,必须学习。记录,巩固,复习


一、冒泡排序是什么?

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

演示冒泡过程的例子(图解)
在这里插入图片描述

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

较为经典的排序算法,

  • 比较相邻的元素

所耗时间:8万程序运行时间:20726ms

二、使用步骤

代码如下(示例):

package com.pine;

import java.util.Arrays;

/**
 * @author sgstar   冒泡排序算法
 * @create 2020-10-16 20:23
 */
public class BubbleSort {
    public static void main(String[] args) {
//        int[] array = {12,11,2,1,3,24,22,243};
        // 排序
//        bubbleSort(array);
        // 使用Arrays工具类,将数组作为字符串返回
//        System.out.println(Arrays.toString(array));

        int[] array = new int[80000];
        for (int i = 0; i < 80000; i++) {
            array[i] = (int) (Math.random() * 8000000);
        }
        long startTime = System.currentTimeMillis();
        bubbleSort(array);
        long endTime = System.currentTimeMillis();
        System.out.println("程序运行时间:" + (endTime - startTime) +"ms");  // 8万程序运行时间:20726ms

    }

    public static void bubbleSort(int[] array) {
        //一定要记住判断边界条件,很多人不注意这些细节,面试官看到你的代码的时候都懒得往下看,你的代码哪个项目敢往里面加?
        if (array == null || array.length <= 1) {
            return;
        }

        int length = array.length;
        // 外层循环控制比较轮数 i 这里,博主写的是 length 但是应该length - 1 就可以了
        for (int i = 0; i < length - 1; i++) {
            // 内层循环控制每一轮比较的次数,每进行一轮排序都会找出一个比较大的数,length - 1 - i;可以减少比较次数
            for (int j = 0; j < length - 1 - i; j++) {
                //前面的数比后面的数大,就进行交换
                if (array[j] > array[j+1]) {
                    int temp = array[j+1];
                    array[j+1] = array[j];
                    array[j] = temp;
                }
            }
        }
    }
}



排序后的结果:
    
[1, 2, 3, 11, 12, 22, 24, 243]
    

总结

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值