m0_67001348 2022-10-13 21:54 采纳率: 88.9%
浏览 26
已结题

java 算法 合并数组

public class PartitionTest {//分治算法 合并排序代码

    private void mergeSort(int a[], int left,int right){
        if(left == right)
        {
            return;
        }
        mergeSort(a,left,(left+right)/2-1);
        mergeSort(a,(left+right)/2+1,right-1 );
        merge(a,left,right);
    }
    private void merge(int a[], int left, int right) {
        int l = left, mid = (left + right) / 2, i = 0;
        int k = mid + 1;
        int[] arr = new int[left - right + 1];//存放排好序的数组
        while (l <= mid && k <= right) {
            if (a[l] > a[k]) {
                arr[i] = a[k];
                i++;
                k++;
            } else {
                arr[i] = a[l];
                i++;
                l++;
            }
        }
        if (l > mid) {
            for (; k <= right; i++, k++) {
                arr[i] = a[k];
            }
        } else {
            for (; l <= mid; i++, l++) {
                arr[i] = a[l];
            }
        }
        for (int j = 0; j < left - right + 1 ; j++) {
            a[left++] = arr[j];
        }
    }

    public static void main(String[] args) {
        int[] a = {2,0};
        new PartitionTest().mergeSort(a,0,a.length-1);
        for (int i = 0; i < a.length; i++) {
            System.out.println(a[i]);
        }
    }
}

为什么爆栈了,同样类似的算法在c++ 我没有爆 不明白啊 这里的算法可能有点问题

  • 写回答

1条回答 默认 最新

  • 心寒丶 全栈领域优质创作者 2022-10-14 09:09
    关注

    你这个 left right 不相等不就死循环了么

    img


    第一次循环进去
    left 0 right 1 ,然后 (left+right)/2-1) =(0+1)/2-1 结果-1 ,第二次进去 left 0 right -1 直接死循环

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 10月22日
  • 已采纳回答 10月14日
  • 修改了问题 10月13日
  • 修改了问题 10月13日
  • 展开全部

悬赏问题

  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题