有关std :: vector的QuickSort的问题

Question about quicksort with std::vector

本文关键字:QuickSort 问题 vector std 有关      更新时间:2023-10-16

以下是我从Internet找到的一些代码,这些代码使用整数数组进行输入。它运行良好,但是如果我将数组更改为向量,它只会打印原始输入95、45、48、98、1、485、65、478、1、2325。它?

#include <iostream>
#include <vector>
using namespace std;

            void printArray(vector<int> array, int n)
            {
                for (int i = 0; i < n; ++i)
                    cout << array[i] << endl;
            }
            void quickSort(vector<int> array, int low, int high)
            {
                int i = low;
                int j = high;
                int pivot = array[(i + j) / 2];
                int temp;
                while (i <= j)
                {
                    while (array[i] < pivot)
                        i++;
                    while (array[j] > pivot)
                        j--;
                    if (i <= j)
                    {
                        temp = array[i];
                        array[i] = array[j];
                        array[j] = temp;
                        i++;
                        j--;
                    }
                }
                if (j > low)
                    quickSort(array, low, j);
                if (i < high)
                    quickSort(array, i, high);
            }
            int main()
            {
                vector<int> array = {95, 45, 48, 98, 1, 485, 65, 478, 1, 2325};
                int n = sizeof(array)/sizeof(array[0]);
                cout << "Before Quick Sort :" << endl;
                printArray(array, n);
                quickSort(array, 0, n);
                cout << "After Quick Sort :" << endl;
                printArray(array, n);
                return (0);
            }

您是通过值将向量传递给 quicksort函数的,这使其在输入向量的副本上操作(因此,原始矢量保持不变(。一个可能的解决方案是通过参考将其传递。因此,quicksort的声明应为:

void quickSort(std::vector<int> &array, int low, int high)

代码的另一个问题是sizeof(array)/sizeof(array[0])不是获取向量大小的正确方法,有效的方法是使用std::vector::size()方法(也在H. Guijt的答案中指出(

  1. 您正在按值传递数组,因此您在QuickSort函数中对其进行的任何更改都不是呼叫者可见的。而是通过引用传递。
  2. sizeof将返回向量的控制块的大小,而不是其存储的字节数。使用vector :: size((获取元素计数。

奖励:使用std ::交换代替该温度变量。