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
相关推荐
徐小夕@趣谈前端几秒前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力问好眼3 分钟前
【信息学奥赛一本通】1275:【例9.19】乘积最大Daydream.V22 分钟前
逻辑回归实例问题解决(LogisticRegression)代码无bug抓狂人22 分钟前
C语言之表达式括号匹配不穿格子的程序员30 分钟前
从零开始写算法——普通数组篇:缺失的第一个正数带刺的坐椅34 分钟前
用 10 行 Java8 代码,开发一个自己的 ClaudeCodeCLI?你信吗?Nebula_g37 分钟前
线程进阶: 无人机自动防空平台开发教程(更新)HAPPY酷44 分钟前
构造与析构:C++ 中对象的温柔生灭rit84324991 小时前
基于MATLAB的环境障碍模型构建与蚁群算法路径规划实现hoiii1871 小时前
MATLAB SGM(半全局匹配)算法实现