时月oe 2019-10-28 09:09 采纳率: 50%
浏览 308
已采纳

关于C++算法中归并排序的问题

求助大神,我写的这个归并排序的代码有什么问题,为什么程序运行后什么也不输出呢?

#include<iostream>
using namespace std;
void erfen(int A[],int low,int high);
void paixu(int A[],int low,int mid,int high);

int main()
{
    int num[2] = {3,4};
    erfen(num, 0,1);
    for (int i = 0; i < 2; i++)
        cout << num[i] << endl;

    return 0;
}
void paixu(int A[], int low, int mid, int high)
{
    int* B = new int[high - low + 1];
    int i = low;
    int j = mid + 1;
    int k = 0;
    while (i <= mid && j <= high)
    {
        if (A[i] <= A[j])B[k++] = A[i++];
        else B[k++] = A[j++];
    }
    while (i <= mid)B[k++] = A[i++];
    while (j <= high) B[k++] = A[j++];
    //填充原数组
    for (int x = low, k = 0; x <= high; i++)
        A[i] = B[k++];
    delete [] B;
}
void erfen(int A[], int low, int high)
{

    if (low < high)
    {
        int mid = (low + high) / 2;
        erfen(A,low,mid);
        erfen(A, mid + 1,high);
        paixu(A, low, mid, high);
    }
}

程序运行后,先是卡住几秒,然后输出“请按任意键继续...”

展开全部

  • 写回答

1条回答 默认 最新

  • dabocaiqq 2019-10-29 01:18
    关注
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部