数据结构和算法——排序算法

目录

排序的分类:

内部排序:

插入排序:

直接插入排序:

希尔排序:

选择排序:

简单选择排序:

堆排序:

交换排序:

冒泡排序:

快速排序

归并排序:

基数排序:

外部排序:


时间复杂度和空间复杂度:

时间频度:语句执行的次数。

java 复制代码
    int total = 0;
    int end = 100;
    for (int i = 1; i < end; i++) {
        total += i;
    }

写法:T(n)=n+1;语句执行了n+1次,因为最后判断一次使他退出,所以+1次。

当n值变大可以忽略:忽略常数项。忽略低次项。

排序的分类:

内部排序:
插入排序:
直接插入排序:
希尔排序:
选择排序:
简单选择排序:

代码:

java 复制代码
public class SelectSort {
    public static void main(String[] args) {
        int[] arr = new int[80000];
        for (int i = 0; i < arr.length; i++) {
            arr[i] = (int) (Math.random() * 80000);
        }
        long startTime = System.currentTimeMillis();
        selectSort(arr);
        long endTime = System.currentTimeMillis() - startTime;
    }

    public static void selectSort(int[] arr) {
        for (int i = 0; i < arr.length - 1; i++) {
            int minIndex = i;
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[j] < arr[minIndex]) {
                    minIndex = j;
                }
            }
            if (minIndex != i) {
                int tmpNum = arr[i];
                arr[i] = arr[minIndex];
                arr[minIndex] = tmpNum;
            }
        }
    }
}
堆排序:

在二叉树的基础上。

交换排序:
冒泡排序:

代码:

java 复制代码
public class BubbleSort {
    public static void main(String[] args) {
        int[] arr = new int[80000];
        for (int i = 0; i < arr.length; i++) {
            arr[i] = (int) (Math.random() * 80000);
        }
        long startTime = System.currentTimeMillis();
        bubbleSort(arr);
        long endTime = System.currentTimeMillis() - startTime;
    }

    public static void bubbleSort(int[] nums) {
        for (int i = 0; i < nums.length - 1; i++) {
            boolean sortEd = true; // 已顺序排序
            for (int j = 0; j < nums.length - 1 - i; j++) {
                if (nums[j] > nums[j + 1]) {
                    int tmp = nums[j];
                    nums[j] = nums[j + 1];
                    nums[j + 1] = tmp;
                    sortEd = false;
                }
            }
            if (sortEd) {
                return;
            }
        }
    }
}
快速排序
归并排序:
基数排序:

是桶排序的升级版。

外部排序:

当数据量太大,无法全部加载到内存总时,需要借助外部存储进行排序。

相关推荐
福大大架构师每日一题18 小时前
milvus v2.6.9 发布:支持主键搜索、段重开机制、日志性能全面提升!
android·java·milvus
独自破碎E18 小时前
【滑动窗口】最长无重复子数组
java·开发语言
GIOTTO情18 小时前
Infoseek 媒介投放系统技术实现:基于与辉同行风波的风险防控架构设计
java·架构·媒体
木井巳18 小时前
【Java】数据类型及运算符重点总结
java·开发语言
码农水水18 小时前
美团Java面试被问:Netty的ByteBuf引用计数和内存释放
java·开发语言·数据库·mysql·算法·面试·职场和发展
a努力。18 小时前
国家电网Java面试被问:分布式Top K问题的解决方案
java·开发语言·分布式·oracle·面试·职场和发展·kafka
码农水水18 小时前
浅谈 MySQL InnoDB 的内存组件
java·开发语言·数据库·后端·mysql·面试
shjita18 小时前
mapreduce输出乱码的处理
java·开发语言·数据库
进阶小白猿18 小时前
Java技术八股学习Day25
java·jvm·学习
是垚不是土18 小时前
基于OpenTelemetry实现分布式链路追踪
java·运维·分布式·目标跟踪·系统架构