算法讲解
思路
选择排序也是一种简单直观的排序算法。它的工作原理很容易理解: 初始时在序列中找到最小(大)元素,放到序列的起始位置作为已排序序列; 然后,再从剩余未排序元素中继续寻找最小(大)元素,放到已排序序列的末尾。 以此类推,直到所有元素均排序完毕。
注意选择排序与冒泡排序的区别:冒泡排序通过依次交换相邻两个顺序不合法的元素位置, 从而将当前最小(大)元素放到合适的位置;而选择排序每遍历一次都记住了当前最小(大)元素的位置,最后仅需一次交换操作即可将其放到合适的位置。
时间复杂度为O(n^2),空间复杂度为O(1)
cpp代码
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
void selectSort1(vector<int>& arr) {
int n = arr.size();
if (n <= 1) return;
int minIndex = 0;
for (int i = 0; i < n - 1; ++i) {
minIndex = i;
for (int j = i + 1; j < n; ++j) {
if (arr[minIndex] > arr[j])
minIndex = j;
}
swap(arr[i], arr[minIndex]);
}
}
void selectSort2(vector<int>& arr) {
int n = arr.size();
if (n <= 1) return;
int begin = 0;
int end = n - 1;
while (begin < end) {
int maxi = begin;
int mini = begin;
for (int i = begin; i <= end; ++i) {
if (arr[i] < arr[mini])
mini = i;
if (arr[i] > arr[maxi])
maxi = i;
}
swap(arr[begin], arr[mini]);
if (maxi == begin)
maxi = mini;
swap(arr[maxi], arr[end]);
++begin;
--end;
}
}
int main() {
vector<int> arr = {6,4,3,7,1,9,5,8,2,10};
cout << "排序前: ";
for (int i = 0; i < 10; i++)
cout << arr[i] << " ";
cout << endl;
selectSort2(arr);
cout << "排序后: ";
for (int i = 0; i < 10; i++)
cout << arr[i] << " ";
cout << endl;
return 0;
}
结果:
|