认识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的数

相关推荐
Fuly10244 分钟前
java面试知识点复习
java·开发语言·面试
郭涤生10 分钟前
std::condition_variable的使用及主要事项
开发语言·c++
小菜鸡桃蛋狗15 分钟前
C++——list
开发语言·c++
hopetomorrow24 分钟前
学习路之PHP --PHP 常用扩展及作用表
开发语言·学习·php
信徒_29 分钟前
API 网关技术选型
java
simple-L629 分钟前
Java开发痛点技术文章大纲
java·开发语言
m0_6356474840 分钟前
Qt打包含有第三方库的软件为应用程序——CQtDeployer
开发语言·数据库·qt
simple-L61 小时前
Vue3 前端开发技术文章大纲
开发语言
南宫萧幕1 小时前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
千寻girling1 小时前
滑动窗口刷了快一个月(26天)了 , 还没有刷完. | 含(操作系统学什么的Java 后端)
java·开发语言·javascript·c++·人工智能·后端·python