Ниже приведен код, который я нашел в интернете и использует целочисленный массив для ввода.Он работает хорошо, но если я изменяю массив на вектор, он просто печатает исходные данные 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);
}