为什么我的merge_sort在c++中不工作

Why my merge_sort in c++ is not working?

本文关键字:c++ 工作 sort 我的 merge 为什么      更新时间:2023-10-16

这是我在c++中使用向量进行归并排序的代码。但它扔给我奇怪的结果:

结果:

输入元素:11 33 12 44 99 34

已排序元素:11 33 33 44 99 99

My Header File is nothing special: "stdafx.h"

#pragma once
#include "targetver.h"
#include <stdio.h>
#include <tchar.h>
#include <iostream>
using namespace std;
代码:

#include "stdafx.h"
#include <iostream>
#include<array>
#include<vector>
//#define array_size(array) (sizeof((array))/sizeof((array[0])))
using namespace std;
template <typename T>
void merge_sort(vector<T>& arr, vector<T>& arr1, vector<T>& arr2) {
    arr.clear();
    int i = 0, j = 0, k = 0;
    for (i = 0; i < arr1.size() && j < arr2.size(); k++) {
        if (arr1.at(i) <= arr2.at(j)) {
            arr.push_back(arr1.at(i));
            i++;
        }
        else if (arr1.at(i) > arr2.at(j)) {
            arr.push_back(arr1.at(j));
            j++;
        }
        k++;
    }
    while (i < arr1.size()) {
        arr.push_back(arr1.at(i));
        i++;
    }
    while (j < arr2.size()) {
        arr.push_back(arr2.at(j));
        j++;
    }
};
template <typename T>
vector<T>merge(std::vector<T>& arr) {
    if (1 < arr.size()) {
        vector<T> arr1(arr.begin(), arr.begin() + arr.size() / 2);
        merge(arr1);//dividing to size 1
        std::vector<T> arr2(arr.begin() + arr.size() / 2, arr.end());
        merge(arr2);
        merge_sort(arr, arr1, arr2);
    }
    return (arr);
    //write_vector(arr);
};

int main()
{
    //Merge Sort
    vector<int> inputVec;
    int size = 6;
    for (int i = 0; i < size; i++) {
        int input;
        cin >> input;
        inputVec.push_back(input);
    }
    vector<int>& newSort=merge(inputVec);
    vector<int>::iterator it;
    for (it = newSort.begin(); it != newSort.end(); ++it)
        cout<<endl<< *it << endl;
    return 0;
}

结果窗口:我的输出谁能指出什么地方不对吗?为什么它会创建重复元素?

查看merge_sort函数中的代码:

for (i = 0; i < arr1.size() && j < arr2.size(); k++) {
    if (arr1.at(i) <= arr2.at(j)) {
        arr.push_back(arr1.at(i));
        i++;
    }
    else if (arr1.at(i) > arr2.at(j)) {
        arr.push_back(arr1.at(j));
        //            ^^^^
        // It should be arr.push_back(arr2.at(j));
        j++;
    }
    k++;
}

arr.push_back(arr1.at(j));替换为arr.push_back(arr2.at(j));,您的代码将像魅力一样工作。