标题:分治法 合并排序算法 但是为什么输出不对呀
取消只看楼主
小cai鸟
Rank: 2
等 级:论坛游民
帖 子:53
专家分:25
注 册:2018-7-13
结帖率:60%
已结贴  问题点数:20 回复次数:3 
分治法 合并排序算法 但是为什么输出不对呀
#include<stdio.h>
#define M 100

int merge(int a[], int start, int mid, int end){
    int b[M];
    int i, j, k = 0;
   
    i = start;
    j = mid + 1;
    while(i<=mid && j<=mid){
        if(a[i] <= a[j])
            b[k++] = a[i++];
        else
            b[k++] = a[j++];
    }
    while(i <= mid)
        b[k++] = a[i++];
    while(j <= end)
        b[k++] = a[j++];
    for(i=0; i<k; i++)
        a[i] = b[i];
    return 1;
}

int mergeSort(int a[], int start, int end){
    int mid;

    if(start < end){
        mid = (start + end) / 2;
        mergeSort(a, start, mid);
        mergeSort(a, mid+1, end);
        merge(a, start, mid, end);
    }
    return 1;
}

int main(){
    int a[M];
    int i;
    int n;

    scanf("%d", &n);
    for(i=0; i<n; i++){
        scanf("%d", &a[i]);
    }
    mergeSort(a, 0, n);
    for(i=0; i<n; i++){
        printf("%d ", a[i]);
    }

    return 0;
}
/*
    感觉写的没毛病  我想问题可能出在merge函数的最后面那个循环,可我不知道怎么改....有大佬知道我问题出在哪里吗?

*/
搜索更多相关主题的帖子: int start mid end i++ 
2018-09-26 11:31
小cai鸟
Rank: 2
等 级:论坛游民
帖 子:53
专家分:25
注 册:2018-7-13
得分:0 
回复 2楼 MeandC
不知道为什么变成这样
2018-09-27 09:19
小cai鸟
Rank: 2
等 级:论坛游民
帖 子:53
专家分:25
注 册:2018-7-13
得分:0 
回复 3楼 MeandC
一定需要指针吗?
2018-09-27 09:19
小cai鸟
Rank: 2
等 级:论坛游民
帖 子:53
专家分:25
注 册:2018-7-13
得分:0 
回复 7楼 rjsp
好的好的 受教了  
不过 我复制你的代码还是没有排序出来呀
而且你的用VC6.0不能编译  Dev-c++倒是可以编译
2018-10-04 20:07



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-490003-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019176 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved