> ### 歸并排序
* 時間復雜度`O(nlogn)`,最壞情況`O(nlogn)`,**穩定**
```
//歸并排序
public void sort5(int[] arr, int left, int right) {
int mid = (left + right) / 2;
if(left < right) {
this.sort5(arr, left, mid);
this.sort5(arr, mid + 1, right);
merge(arr, left, mid, right);
}
}
public void merge(int[] arr, int left, int mid, int right) {
int[] temp = new int[right - left + 1];
int t1 = left, t2 = mid + 1, t = 0;
while(t1 <= mid && t2 <= right) {
temp[t++] = arr[t1] < arr[t2] ? arr[t1++] : arr[t2++];
}
while(t1 <= mid) {
temp[t++] = arr[t1++];
}
while(t2 <= right) {
temp[t++] = arr[t2++];
}
t = 0;
while(t < temp.length) {
arr[left + t] = temp[t];
t++;
}
}
```
- asD
- Java
- Java基礎
- Java編譯器
- 反射
- collection
- IO
- JDK
- HashMap
- ConcurrentHashMap
- LinkedHashMap
- TreeMap
- 阻塞隊列
- java語法
- String.format()
- JVM
- JVM內存、對象、類
- JVM GC
- JVM監控
- 多線程
- 基礎概念
- volatile
- synchronized
- wait_notify
- join
- lock
- ThreadLocal
- AQS
- 線程池
- Spring
- IOC
- 特性介紹
- getBean()
- creatBean()
- createBeanInstance()
- populateBean()
- AOP
- 基本概念
- Spring處理請求的過程
- 注解
- 微服務
- 服務注冊與發現
- etcd
- zk
- 大數據
- Java_spark
- 基礎知識
- Thrift
- hdfs
- 計算機網絡
- OSI七層模型
- HTTP
- SSL
- 數據庫
- Redis
- mysql
- mybatis
- sql
- 容器
- docker
- k8s
- nginx
- tomcat
- 數據結構/算法
- 排序算法
- 快排
- 插入排序
- 歸并排序
- 堆排序
- 計算時間復雜度
- leetcode
- LRU緩存
- B/B+ 樹
- 跳躍表
- 設計模式
- 單例模式
- 裝飾者模式
- 工廠模式
- 運維
- git
- 前端
- thymeleaf
- 其他
- 代碼規范
- work_project
- Interview