#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;
}
求解为什么这个归并排序得不到正确的结果
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- vevemom 2022-04-24 09:26关注
sort最后加几行
for (int i = low; i <= high; i++)
{
arr[i] = carr[i];
}一次排好的结果要赋值给原数组 否则你每次排序都是从原始数组取值 并没有发生任何改变 结果肯定不对
解决 无用评论 打赏 举报
悬赏问题
- ¥15 依据报错在原代吗格式的基础上解决问题
- ¥15 在虚拟机中安装flash code
- ¥15 单片机stm32f10x编写光敏电阻调节3.3伏大功率灯亮度(光强越大灯越暗,白天正常光强灯不亮,使用ADC,PWM等模块)望各位找一下错误或者提供一个可实现功能的代码
- ¥20 verilog状态机方法流水灯
- ¥15 pandas代码实现不了意图
- ¥15 GD32H7 从存储器到外设SPI传输数据无法重复启用DMA
- ¥25 LT码在高斯信道下的误码率仿真
- ¥45 渲染完成之后将物体的材质贴图改变,自动化进行这个操作
- ¥15 yolov5目标检测并显示目标出现的时间或视频帧
- ¥15 电视版的优酷可以设置电影连续播放吗?