千修鸣 2022-04-23 16:55 采纳率: 0%
浏览 28

求解为什么这个归并排序得不到正确的结果


#include <stdio.h>


//归并排序算法 

void sort(int *arr, int *carr, int low, int mid, int high)
{
    int i = low; 
    int k = low; 
    int j = mid+1;
    while(i<=mid && j<=high)
    { //将两边小的加进去 
        if(arr[i] < arr[j])
        {
            carr[k++] = arr[i++];
        }
        else 
        {
            carr[k++] = arr[j++];
        }
    }
    
    while(i<=mid) carr[k++] = arr[i++]; //将左边剩余的部分加进去 

    while(j<=high) carr[k++] = arr[j++]; //将右边剩余的部分加进去 
}



void mergerSort(int *arr, int *carr, int low, int high)
{
    int mid = (low + high) / 2;
    if(low<high)
    {
        mergerSort(arr, carr, low, mid);
        mergerSort(arr, carr, mid+1, high);
        sort(arr, carr, low, mid, high);
    }
    else return;
}







int main()
{
    int arr[] = {49,38,65,11,97,13,27,76,101,15};
    int length = sizeof(arr) / sizeof(arr[0]);
    int carr[length] = {0};

    mergerSort(arr, carr, 0, length-1);
    
    for(int i=0; i<length; i++)
    {
        printf("%d ",carr[i]);
    }
    printf("\n");
    return 0;
}
  • 写回答

1条回答 默认 最新

  • vevemom 2022-04-24 09:26
    关注

    sort最后加几行
    for (int i = low; i <= high; i++)
    {
    arr[i] = carr[i];
    }

    一次排好的结果要赋值给原数组 否则你每次排序都是从原始数组取值 并没有发生任何改变 结果肯定不对

    评论

报告相同问题?

问题事件

  • 创建了问题 4月23日

悬赏问题

  • ¥15 依据报错在原代吗格式的基础上解决问题
  • ¥15 在虚拟机中安装flash code
  • ¥15 单片机stm32f10x编写光敏电阻调节3.3伏大功率灯亮度(光强越大灯越暗,白天正常光强灯不亮,使用ADC,PWM等模块)望各位找一下错误或者提供一个可实现功能的代码
  • ¥20 verilog状态机方法流水灯
  • ¥15 pandas代码实现不了意图
  • ¥15 GD32H7 从存储器到外设SPI传输数据无法重复启用DMA
  • ¥25 LT码在高斯信道下的误码率仿真
  • ¥45 渲染完成之后将物体的材质贴图改变,自动化进行这个操作
  • ¥15 yolov5目标检测并显示目标出现的时间或视频帧
  • ¥15 电视版的优酷可以设置电影连续播放吗?