认识O(NlogN)的排序

参考视频:一周刷爆LeetCode,算法大神左神(左程云)耗时100天打造算法与数据结构基础到高级全家桶教程,直击BTAJ等一线大厂必问算法面试题真题详解(马士兵) 点击观看

文章目录


中点

int mid = (L + R) / 2;
int mid = L + (R - L) / 2;(防止溢出)
int mid = L + ((R - L) >> 1);

复制代码
>> 1 相当于除以2,但位运算比算术运算更快
注意括号必须加,因为移位运算符优先级低于加法

使用递归方法求一个数组L到R的最大值

java 复制代码
public class Main {
    public static void main(String[] args) {
        //使用递归方法求数组中L到R的最大值
        int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
        System.out.println(getMax(arr, 0, arr.length - 1));
    }
    public static int getMax(int[] arr, int L, int R) {
        if (L == R) {
            return arr[L];
        }
        int mid = L + ((R - L) >> 1);
        int leftMax = getMax(arr, L, mid);
        int rightMax = getMax(arr, mid + 1, R);
        return Math.max(leftMax, rightMax);
    }
}

归并排序

java 复制代码
public class Main {
    public static void main(String[] args) {
        //归并排序
        int[] arr = {8, 4, 5, 7, 1, 3, 6, 2};
        mergeSort(arr, 0, arr.length - 1);
    }
    public static void mergeSort(int[] arr, int left, int right) {
        int mid = (left + right) / 2;
        mergeSort(arr, left, mid);
        mergeSort(arr, mid + 1, right);
        merge(arr, left, mid, right);
    }
    public static void merge(int[] arr, int left, int mid, int right) {
        int[] temp = new int[right - left + 1];
        int i = left, j = mid + 1, k = 0;
        while (i <= mid && j <= right) {
            if (arr[i] <= arr[j]) {
                temp[k++] = arr[i++];
            } else {
                temp[k++] = arr[j++];
            }
        }
        while (i <= mid) {
            temp[k++] = arr[i++];
        }
        while (j <= right) {
            temp[k++] = arr[j++];
        }
        for (int m = 0; m < k; m++) {
            arr[left + m] = temp[m];
        }
        System.out.println("归并:");
        for (int n = left; n <= right; n++) {
            System.out.print(arr[n] + " ");
        }
    }
}
java 复制代码
public class Main {
    public static void main(String[] args) {
        //归并排序求解小和问题
        int[] arr = {8, 4, 5, 7, 1, 3, 6, 2};
        int sum = mergeSort(arr, 0, arr.length - 1);
        System.out.println(sum);
    }
    public static int mergeSort(int[] arr, int left, int right) {
        if (left == right) {
            return 0;
        }
        int mid = (left + right) / 2;
        return mergeSort(arr, left, mid)+
        mergeSort(arr, mid + 1, right)+
        merge(arr, left, mid, right);
    }
    public static int merge(int[] arr, int left, int mid, int right) {
        int[] temp = new int[right - left + 1];
        int i = left, j = mid + 1, k = 0;
        int res = 0;
        while (i <= mid && j <= right) {
            res+=arr[i] < arr[j] ? arr[i] * (right - j + 1) : 0;
            if (arr[i] <= arr[j]) {
                temp[k++] = arr[i++];
            } else {
                temp[k++] = arr[j++];
            }
        }
        while (i <= mid) {
            temp[k++] = arr[i++];
        }
        while (j <= right) {
            temp[k++] = arr[j++];
        }
        for (int m = 0; m < k; m++) {
            arr[left + m] = temp[m];
        }
        System.out.println("归并:");
        for (int n = left; n <= right; n++) {
            System.out.print(arr[n] + " ");
        }
        System.out.println();
        return res;
    }
    //8, 4, 5, 7, 1, 3, 6, 2
    //4+9+1+13+1=28
}

快速排序

例子

情况1:左边是小于等于num的数右边是大于num的数

情况2:左边是小于num的数中间是等于num的数右边是大于num的数

相关推荐
折哥的程序人生 · 物流技术专研几秒前
《Java 100 天进阶之路》第93篇:Redis实战应用:缓存策略与分布式锁(2026版)
java·redis·缓存·面试·架构·求职招聘
瓦特what?几秒前
位运算核心技巧与应用
java·jvm·算法
人道领域3 分钟前
【LeetCode刷题日记】90.子集Ⅱ--- 归纳题解
java·开发语言·leetcode
ch.ju9 分钟前
Java Programming Chapter 4——Characteristics of inheritance
java·开发语言
复园电子10 分钟前
企业PDF批量盖章开发集成指南:API对接OA/LIMS系统,高并发落地实战
开发语言·python·pdf
就叫_这个吧11 分钟前
tomcat在idea控制台乱码问题解决
java·tomcat·intellij-idea
SunnyDays101115 分钟前
如何使用 C# 自动调整 Excel 行高和列宽
开发语言·c#·excel
霸道流氓气质20 分钟前
Spring AI Alibaba Skills 完整实战:从零构建智能会议助手
java·人工智能·spring
a诠释淡然27 分钟前
C++模板元编程—现代C++的黑魔法
开发语言·c++
极客先躯31 分钟前
高级java每日一道面试题-2026年02月04日-实战篇[Docker]-如何在容器之间共享数据?
java·运维·网络·docker·容器·自动化·高级面试题