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
相关推荐
夏鹏今天学习了吗18 分钟前
【LeetCode热题100(95/100)】寻找重复数TTGGGFF3 小时前
控制系统建模仿真(四):线性控制系统的数学模型正在努力Coding4 小时前
SpringAI - 工具调用晚风吹长发4 小时前
初步了解Linux中的命名管道及简单应用和简单日志我尽力学4 小时前
面试 总结爬台阶的蚂蚁4 小时前
Spring AI Alibaba基础概念Σίσυφος19004 小时前
Halcon中霍夫直线案例计算机学姐5 小时前
基于SpringBoot的演唱会抢票系统huohuopro5 小时前
Mybatis的七种传参方式Lee_SmallNorth5 小时前
变态需求之【角色不同访问数据库的用户不同】