#include <iostream> #include <vector> // 归并排序 void merge(std::vector<int>& arr, int left, int mid, int right) { int n1 = mid - left + 1; int n2 = right - mid; std::vector<int> L(n1); std::vector<int> R(n2); for (int i = 0; i < n1; i++) { L[i] = arr[left + i]; } for (int j = 0; j < n2; j++) { R[j] = arr[mid + 1 + j]; } int i = 0, j = 0, k = left; while (i < n1 && j < n2) { if (L[i] <= R[j]) { arr[k] = L[i]; i++; } else { arr[k] = R[j]; j++; } k++; } while (i < n1) { arr[k] = L[i]; i++; k++; } while (j < n2) { arr[k] = R[j]; j++; k++; } } void mergeSort(std::vector<int>& arr, int left, int right) { if (left < right) { int mid = left + (right - left) / 2; mergeSort(arr, left, mid); mergeSort(arr, mid + 1, right); merge(arr, left, mid, right); } } // 数组倒序 void reverseArray(std::vector<int>& arr) { int start = 0; int end = arr.size() - 1; while (start < end) { std::swap(arr[start], arr[end]); start++; end--; } } int main() { std::vector<int> arr = {}; // 归并排序 mergeSort(arr, 0, arr.size() - 1); std::cout << "归并排序后的数组:"; for (int num : arr) { std::cout << num << " "; } std::cout << std::endl; // 数组倒序 reverseArray(arr); std::cout << "数组倒序结果:"; for (int num : arr) { std::cout << num << " "; } std::cout << std::endl; return 0; }注释
时间: 2024-04-16 15:30:05 浏览: 14
这是一个包含归并排序和数组倒序功能的程序。它使用了两个函数:mergeSort和reverseArray。
mergeSort函数实现了归并排序算法。它接受一个整数向量arr,并通过将数组分成较小的子数组,然后将这些子数组逐步合并为一个有序数组来对其进行排序。算法的主要思想是将数组分成两个部分,然后递归地对这两个部分进行排序,并在最后将它们合并为一个有序数组。
merge函数用于合并两个有序数组。它接受一个整数向量arr,以及左、中、右三个索引值,表示需要合并的子数组。在合并过程中,它创建了两个临时向量L和R来存储子数组的元素,并根据大小比较逐个将元素放入原始数组arr中。
在主函数中,程序首先定义了一个空的整数向量arr。然后,它调用mergeSort函数对arr进行排序,并输出排序后的结果。接着,它调用reverseArray函数对arr进行倒序,并输出倒序后的结果。
最后,程序返回0表示正常运行结束。
如果你对这段代码有任何疑问,请随时提问。
相关问题
C++ vector 实现归并排序
你可以使用C++的vector来实现归并排序算法。下面是一个简单的示例代码:
```cpp
#include <iostream>
#include <vector>
using namespace std;
// 合并两个有序数组
void merge(vector<int>& arr, int left, int mid, int right) {
vector<int> temp(right - left + 1);
int i = left, j = mid + 1, k = 0;
while (i <= mid && j <= right) {
if (arr[i] <= arr[j]) {
temp[k++] = arr[i++];
} else {
temp[k++] = arr[j++];
}
}
while (i <= mid) {
temp[k++] = arr[i++];
}
while (j <= right) {
temp[k++] = arr[j++];
}
for (int p = 0; p < k; p++) {
arr[left + p] = temp[p];
}
}
// 归并排序
void mergeSort(vector<int>& arr, int left, int right) {
if (left >= right) {
return;
}
int mid = left + (right - left) / 2;
mergeSort(arr, left, mid);
mergeSort(arr, mid + 1, right);
merge(arr, left, mid, right);
}
int main() {
vector<int> arr = {9, 5, 1, 8, 3, 7, 4, 2, 6};
mergeSort(arr, 0, arr.size() - 1);
for (int num : arr) {
cout << num << " ";
}
return 0;
}
```
这段代码定义了两个函数:`merge` 和 `mergeSort`。`merge` 函数用于合并两个有序数组,`mergeSort` 函数用于递归地将数组划分为子数组并进行排序。在 `main` 函数中,我们可以看到如何使用vector来实现归并排序并打印排序后的结果。
希望这可以帮助到你!如果你有任何其他问题,请随时问我。
归并排序c++设置升序降序
归并排序是一种稳定的排序算法,它可以用于升序或降序排序。下面是一个示例代码,演示了如何使用归并排序算法来实现升序和降序排序:
```cpp
#include <iostream>
#include <vector>
// 合并两个有序数组
void merge(std::vector<int>& arr, int left, int mid, int right, bool ascending) {
int n1 = mid - left + 1;
int n2 = right - mid;
std::vector<int> L(n1), R(n2);
for (int i = 0; i < n1; i++) {
L[i] = arr[left + i];
}
for (int j = 0; j < n2; j++) {
R[j] = arr[mid + 1 + j];
}
int i = 0, j = 0, k = left;
// 升序排序
if (ascending) {
while (i < n1 && j < n2) {
if (L[i] <= R[j]) {
arr[k] = L[i];
i++;
} else {
arr[k] = R[j];
j++;
}
k++;
}
}
// 降序排序
else {
while (i < n1 && j < n2) {
if (L[i] >= R[j]) {
arr[k] = L[i];
i++;
} else {
arr[k] = R[j];
j++;
}
k++;
}
}
while (i < n1) {
arr[k] = L[i];
i++;
k++;
}
while (j < n2) {
arr[k] = R[j];
j++;
k++;
}
}
// 归并排序函数
void mergeSort(std::vector<int>& arr, int left, int right, bool ascending) {
if (left < right) {
int mid = left + (right - left) / 2;
mergeSort(arr, left, mid, ascending);
mergeSort(arr, mid + 1, right, ascending);
merge(arr, left, mid, right, ascending);
}
}
// 打印数组函数
void printArray(const std::vector<int>& arr) {
for (int i = 0; i < arr.size(); i++) {
std::cout << arr[i] << " ";
}
std::cout << std::endl;
}
int main() {
std::vector<int> arr = {5, 2, 8, 4, 1};
std::cout << "原始数组: ";
printArray(arr);
// 使用归并排序进行升序排序
mergeSort(arr, 0, arr.size() - 1, true);
std::cout << "升序排序结果: ";
printArray(arr);
// 使用归并排序进行降序排序
mergeSort(arr, 0, arr.size() - 1, false);
std::cout << "降序排序结果: ";
printArray(arr);
return 0;
}
```
在上面的代码中,`merge` 函数用于合并两个有序数组。`mergeSort` 函数使用归并排序算法对数组进行排序。通过传递 `true` 或 `false` 给 `ascending` 参数,可以设置排序的升序或降序。`printArray` 函数用于打印数组的元素。
注意:这只是一个简单的示例代码,为了方便理解,数组元素直接在代码中定义。在实际应用中,你可能需要修改代码以适应不同的输入方式。