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

目录

排序的分类:

内部排序:

插入排序:

直接插入排序:

希尔排序:

选择排序:

简单选择排序:

堆排序:

交换排序:

冒泡排序:

快速排序

归并排序:

基数排序:

外部排序:


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

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

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;
            }
        }
    }
}
快速排序
归并排序:
基数排序:

是桶排序的升级版。

外部排序:

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

相关推荐
RainbowSea11 小时前
12. LangChain4j + 向量数据库操作详细说明
java·langchain·ai编程
RainbowSea11 小时前
11. LangChain4j + Tools(Function Calling)的使用详细说明
java·langchain·ai编程
考虑考虑15 小时前
Jpa使用union all
java·spring boot·后端
用户37215742613515 小时前
Java 实现 Excel 与 TXT 文本高效互转
java
浮游本尊16 小时前
Java学习第22天 - 云原生与容器化
java
聚客AI17 小时前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
渣哥18 小时前
原来 Java 里线程安全集合有这么多种
java
间彧18 小时前
Spring Boot集成Spring Security完整指南
java
间彧18 小时前
Spring Secutiy基本原理及工作流程
java
Java水解19 小时前
JAVA经典面试题附答案(持续更新版)
java·后端·面试