c++置换选择排序代码
时间: 2023-07-02 15:06:29 浏览: 56
以下是C++中实现置换选择排序的代码:
```c++
void swap(int* a, int* b) {
int temp = *a;
*a = *b;
*b = temp;
}
void selectionSort(int arr[], int n) {
int i, j, min_idx;
for (i = 0; i < n-1; i++) {
min_idx = i;
for (j = i+1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
swap(&arr[min_idx], &arr[i]);
}
}
```
这个算法的时间复杂度为O(n^2),其中n是数组的大小。这个算法的思路是:每次找到未排序的部分中最小的元素,并将其与未排序部分的第一个元素交换。这样,未排序部分的第一个元素就是已排序部分中最后一个元素。重复这个过程,直到所有元素都被排序。
相关问题
c++置换选择排序完整代码
下面是C++实现的置换选择排序的完整代码:
```
#include <iostream>
using namespace std;
void swap(int &x, int &y) {
int temp = x;
x = y;
y = temp;
}
void selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
int min_idx = i;
for (int j = i + 1; j < n; j++)
if (arr[j] < arr[min_idx])
min_idx = j;
if (min_idx != i)
swap(arr[min_idx], arr[i]);
}
}
int main() {
int arr[] = {64, 25, 12, 22, 11};
int n = sizeof(arr) / sizeof(arr[0]);
selectionSort(arr, n);
cout << "Sorted array: \n";
for (int i = 0; i < n; i++)
cout << arr[i] << " ";
cout << endl;
return 0;
}
```
在上面的代码中,我们先定义了一个 `swap` 函数,用于交换两个数。然后定义了 `selectionSort` 函数,该函数使用置换选择排序算法对数组进行排序。最后,在 `main` 函数中,我们创建了一个数组,调用 `selectionSort` 函数对其进行排序,并输出排序后的结果。
置换选择排序代码c++
以下是使用 C++ 编写的置换选择排序代码:
```c++
#include <iostream>
using namespace std;
void swap(int &a, int &b) {
int temp = a;
a = b;
b = temp;
}
void selectionSort(int arr[], int n) {
for (int i = 0; i < n - 1; i++) {
int minIndex = i;
for (int j = i + 1; j < n; j++) {
if (arr[j] < arr[minIndex]) {
minIndex = j;
}
}
if (minIndex != i) {
swap(arr[i], arr[minIndex]);
}
}
}
int main() {
int arr[] = { 64, 25, 12, 22, 11 };
int n = sizeof(arr) / sizeof(arr[0]);
selectionSort(arr, n);
cout << "Sorted array: ";
for (int i = 0; i < n; i++) {
cout << arr[i] << " ";
}
cout << endl;
return 0;
}
```
在此代码中,我们首先定义了一个 `swap` 函数,用于交换两个数的值。然后我们实现了一个 `selectionSort` 函数,该函数使用循环遍历数组,并在每个循环中查找最小元素的索引。如果找到了最小元素,则将其与当前元素交换。最后,我们在主函数中调用 `selectionSort` 函数来对数组进行排序,并打印排序后的结果。