合并排序-细分错误

马诺吉

我从事Python编程已有一年多了,而我刚回到C ++,学习了一些基本算法。我从合并排序开始,但是它给了我一个细分错误。帮助将不胜感激。我想我已经调试了发生的地方,但是我不明白为什么。

#include <iostream>
using namespace std;
void* merge(int array1[], int array2[], int low, int mid, int high){
    int i, j, k;
    for (i = low,j = mid, k = low; i < mid, j < high; k++){
        if (array1[i] < array1[j]){
            array2[k] = array1[i];
            i++;
            }
        else{
            array2[k] = array1[j];
            j++;
        }
    }
    if (i == mid){
        for (; j < high; j++, k++){
            array2[k] = array1[j];
            }
    }
else{
    for (; i < mid; i++, k++){
        array2[k] = array1[i];
    }
}
void* merge_sort(int array1[], int copy[], int low, int high){
    int mid;
    int range = high - low;
    if (range == 1)
        copy[low] = array1[low];
    else{
        mid = low + range/2;
        merge_sort(array1, copy, low, mid);
        // Segmentation error seems to be here.
        merge_sort(array1, copy, mid, high);
     }
     merge(array1, copy, low, mid, high);
}

int main()
{
    int n, temp;
    cout << "How many numbers do you want to enter?" << endl;
    cin >> n;
    int numarray[n];
    for (int i = 0; i < n; i++){
        cin >> numarray[i];
    }
    int dumarray[n];  // Used for filling elements from merge sort
    merge_sort(numarray, dumarray, 0, n);
    cout << "Merge Sort" << endl;
    for (int i = 0; i < n; i++){
        cout << dumarray[i] << endl;
    } 
    return 0;
}

编辑:

#include <iostream>
using namespace std;

void merge_sort(int [], int [], int, int);

void merge(int array1[], int array2[], int low, int mid, int high){
    int i, j, k;
    for (i = low,j = mid, k = low; i < mid, j < high; k++){
        if (array1[i] < array1[j]){
            array2[k] = array1[i];
            i++;
            }
        else{
            array2[k] = array1[j];
            j++;
        }
    }
    if (i == mid){
        for (; j < high; j++, k++){
            array2[k] = array1[j];
            }
    }
    else{
        for (; i < mid; i++, k++){
            array2[k] = array1[i];
            }
    }
}

void merge_sort(int array1[], int copy[], int low, int high){
    int mid;
    int range = high - low;
    mid = low + range/2;
    if (range == 1)
        copy[low] = array1[low];
    else{
        mid = low + range/2;
        merge_sort(array1, copy, low, mid);
        merge_sort(array1, copy, mid, high);
    merge(array1, copy, low, mid, high);
    }
}
int main(){
    int n, temp;
cout << "How many numbers do you want to enter?" << endl;
cin >> n;
int numarray[n];
for (int i = 0; i < n; i++){
    cin >> numarray[i];
}
    int dumarray[n];
    merge_sort(numarray, dumarray ,0, n);
    for (int i = 0; i < n; i++){
        cout << dumarray[i] << endl;
    }

}
digital_revenant

中值的计算似乎是错误的。尝试计算为

mid = low + (high-low)/2

编辑:merge(array1, copy, low, mid, high);在else括号内移动

else
{
    mid = low + range/2;
    merge_sort(array1, copy, low, mid);
    merge_sort(array1, copy, mid, high);
    merge(array1, copy, low, mid, high);
}

merge功能也有很多错误。初始for循环中的条件检查i < mid, j < high由逗号分隔,这意味着它仅检查j < highi并舍弃了条件检查。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

合并排序链表给出细分错误

来自分类Dev

我在合并排序时遇到细分错误

来自分类Dev

合并排序算法错误

来自分类Dev

错误合并排序输出

来自分类Dev

合并排序错误 + 警告

来自分类Dev

合并排序错误:分段错误

来自分类Dev

Python中的简单合并排序错误

来自分类Dev

合并排序-堆栈损坏错误

来自分类Dev

F#错误和合并排序

来自分类Dev

无法找出合并排序中的错误

来自分类Dev

合并排序-堆栈损坏错误

来自分类Dev

合并排序分段错误c ++

来自分类Dev

C ++-合并排序-无法识别错误

来自分类Dev

Python中的简单合并排序错误

来自分类Dev

合并排序堆栈溢出错误

来自分类Dev

如何在我的“合并排序”实现中发现错误?

来自分类Dev

天真的指针算术合并排序返回错误

来自分类Dev

合并排序中具有cout的分段错误

来自分类Dev

Haskell合并排序中的编译错误

来自分类Dev

执行合并排序算法的系统堆栈错误

来自分类Dev

超出范围错误-合并排序算法

来自分类Dev

此合并排序实现中的错误是什么?

来自分类Dev

拆分反转的合并排序实现中的错误在哪里

来自分类Dev

合并排序程序中的 Ocaml 类型错误

来自分类Dev

合并排序(分段错误(Xore Dumped))C++

来自分类Dev

收益率合并排序函数中的错误

来自分类Dev

合并排序就地报告索引超出范围错误

来自分类Dev

C ++中的HackerRank大排序细分错误

来自分类Dev

Scala参数化合并排序-令人困惑的错误消息