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

相关推荐
wellc18 小时前
java进阶知识点
java·开发语言
听风吹等浪起18 小时前
用Python和Pygame从零实现坦克大战
开发语言·python·pygame
灰色小旋风18 小时前
力扣合并K个升序链表C++
java·开发语言
_MyFavorite_18 小时前
JAVA重点基础、进阶知识及易错点总结(28)接口默认方法与静态方法
java·开发语言·windows
取码网18 小时前
最新在线留言板系统PHP源码
开发语言·php
环黄金线HHJX.18 小时前
龙虾钳足启发的AI集群语言交互新范式
开发语言·人工智能·算法·编辑器·交互
旖-旎18 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择
不写八个19 小时前
PHP教程006:ThinkPHP项目入门
开发语言·php
helx8219 小时前
SpringBoot中自定义Starter
java·spring boot·后端
_MyFavorite_19 小时前
JAVA重点基础、进阶知识及易错点总结(31)设计模式基础(单例、工厂)
java·开发语言·设计模式