当前位置: 首页 > article >正文

算法之排序

概述

记录排序算法。

1 选择排序

在这里插入图片描述

**
     * 选择排序
     * 思路:遍历数组,找出(选择)最小的元素,然后和最左边的元素交换。接下来,再从第二个元素开始遍历整个数组。再找到最小的元素,再和第二个元素交换。
     * 重复该过程,直至遍历完成。
     * 时间复杂度:n^2
     * 空间复杂度:1(原地排序,除了临时变量不需要额外空间)
     * @param arr 数组
     * @return 排好序的数组
     */
    public static int[] selectSort(int[] arr){
        // 边界条件
        if(arr.length < 1){
            return arr;
        }

        // 0 - n
        // 1 - n
        // ...
        // i - n
        for(int i = 0; i < arr.length; i++){
            int minIndex = i;
            // 在i-n范围内找最小的
            for(int j = i+1; j < arr.length; j++){
                if(arr[minIndex] > arr[j]){
                    minIndex = j;
                }
            }
            swap(i, minIndex, arr);
        }

        return arr;
    }

    /**
     * 索引i和j位置的元素交换
     * @param i 索引
     * @param j 索引
     * @param arr 数组
     */
    public static void swap(int i, int j, int[] arr){
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }

2 冒泡排序

/**
     * 2冒泡排序
     * 关键词:两两比较
     * 思路:
     * 第一次遍历,从0到n-1遍历数组。两两比较,大的元素往后排,最后遍历结束时,最大的元素就排在了数组末尾。
     * 第二次遍历,从0到n-2遍历数组。两两比较,大的元素往后排,最后遍历结束时,0到n-2中最大的元素就排在了数组n-1的位置处。
     * ...
     * 时间复杂度:n^2
     * 空间复杂度:1
     * 注意:因为是j+1,为防止越界,添加条件1:j <= i-1;又因为是i-1,添加条件2:i > 0;
     * @param arr 数组
     * @return 排好序的数组
     */
    public static int[] bubbleSort(int[] arr){
        // 边界条件
        if(arr.length < 2){
            return arr;
        }

        for(int i = arr.length - 1; i > 0; i--){
            // 从0到i遍历,两两比较
            for(int j = 0; j <= i-1; j++){
                if(arr[j] > arr[j+1]){
                    swap(j, j+1, arr);
                }
            }
        }

        return arr;
    }

3 插入排序

/**
     * 插入排序
     * 理解:打牌,在发牌时,先整理好手上的牌。拿到新发的牌后,往手上已经整理好的牌中插入。
     * 思路:
     * 从0到0,自己和自己比,不用排序
     * 从0到1,小的往前排,直至排到第一个位置
     * 从0到2,小的往前排,直至拍到第一个位置或者前面的更小
     * @param arr 数组
     * @return 有序数组
     */
    public static int[] insertSort(int[] arr){
        if(arr == null || arr.length < 2){
            return arr;
        }

        for(int i = 0; i < arr.length; i++){
            for(int j = i; j >= 0; j--){
                if(j-1 < 0){
                    continue;
                }
                if(arr[j-1] > arr[j]){
                    swap(j, j-1, arr);
                }
            }
        }

        return arr;
    }

http://www.kler.cn/a/350852.html

相关文章:

  • 【数据库初阶】MySQL中表的约束(上)
  • 2025.1.15——四、布尔注入
  • 简历_使用优化的Redis自增ID策略生成分布式环境下全局唯一ID,用于用户上传数据的命名以及多种ID的生成
  • 【k8s面试题2025】3、练气中期
  • LabVIEW与WPS文件格式的兼容性
  • 【Git 】探索 Git 的魔法——git am 与补丁文件的故事
  • Flutter结合鸿蒙next 中数据类型转换的高级用法:dynamic 类型与其他类型的转换解析
  • shell错误修改
  • 无人机之放电速率篇
  • 浙大数据结构:KMP 字符串匹配算法比较
  • linux系统账号安全应该如何设置
  • 第2节 如何学习鸿蒙技术
  • React(四) 事件总线,setState的原理,PureComponent优化React性能,ref获取类组件与函数组件
  • cisco网络安全技术第3章测试及考试
  • excel如何把年龄转换为日期
  • HTML5_标签_各类表格的实现
  • 【排序】——1.冒泡排序法(含优化)
  • 嵌套之美:广义表,在数据层层叠叠之间,展现信息的层次
  • RT-Thread线程的定义和属性
  • 【星闪开发连载】WS63E模组的速度测试
  • 3D 数字人与 2D 数字人的区别
  • 代码随想录算法训练营第八天(1)|哈希表理论基础
  • 线程简单的用例
  • Vue3动态组件component不生效问题解决方法
  • Linux的GDB学习与入门
  • RabbitMQ是什么?