public static void mergeSort1(int[] arr){
if(arr ==null || arr.length <2){
return;
}
process(arr, 0 , arr.length-1);
}
public static void process(int[] arr ,int L ,int R){
if(L ==R){
return;
}
int mid = L +((R-L)>>1);
process(arr , L , mid);
process(arr , mid+1 , R);
merge(arr , L , mid ,R);
}
public static void merge(int[] arr , int L , int M , int R){
int[] help = new int[R-L+1];
int i =0;
int p1 = L;
int p2 = M+1;
while(p1 <= M && p2 <= R){
help[i++] = arr[p1] <= arr[p2] ? arr[p1++] :arr[p2++];
}
while (p1 <= M){
help[i++] = arr[p1++];;
}
while (p2 <= R){
help[i++] = arr[p2++];;
}
for (i = 0; i < help.length; i++) {
arr[L+i] = help[i];
}
}
归并排序(递归实现)
听风客12024-07-17 20:30
相关推荐
北城以北88881 小时前
RocketMQ简介折哥的程序人生 · 物流技术专研8 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)一条泥憨鱼8 小时前
【Redis】数据类型和常用命令云烟成雨TD8 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)程序员二叉9 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结周航宇JoeZhou9 小时前
JB3-9-SpringAI(二)好家伙VCC9 小时前
Web Components主题热切换方案揭秘慕木沐9 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo想吃火锅10059 小时前
【leetcode】14.最长公共前缀js焦虑的说说10 小时前
秒杀系统设计方案