0、选择排序
基本思想:在每一趟排序中,从待排序子表中选出关键字最小(大)的元素放在最终的位置。
怎么选?有2种典型的选择方法
- 直接选择排序
- 堆排序
1、直接选择排序 (direct_select Sort)
思想: 在待排序的子表中找出最小(大)元素,与第一个元素互换位置;然后在”除去第一个元素”的子表中再找出最小(大)的元素,与当前子表的第一个元素互换位置…依此类推,直到第n-1个元素(倒数第二个数)和第n个元素(最后一个数)比较为止
语言很苍白,用图例来解决
例 : 数据表 Arr[] = {2, 1, 6, 5, 3} 直接选择排序算法递增
注释 : 每次利用一个”迭代器” min 遍历一遍数据(子)表,找到当前表中的最小值的下标值( min 来记录),与第一个元素互换即可。
直接选择排序算法分析:
- 稳定性 : 不稳定排序
- 时间复杂度 : 比较次数:(n-1)+(n-2)+…+1=n(n-1)/2 所以是 O(n2)
- 空间性能 : 1个辅助空间
代码:
#include <iostream>
using namespace std;
void Swap(int &a, int &b)
{
int temp;
temp = a;
a = b;
b = temp;
}
void Direct_SelectSort(int * pArr, int len)
{
for(int i = 0; i < len-1; i++)
{
int min = i;
for(int j = i+1; j<len;j++)
{
if(pArr[j] < pArr[min])
{
min = j;
}
}
Swap(pArr[min], pArr[i]);
}
return;
}
int main()
{
int Arr[] = {2,1,6,5,3};
int len = 5;
Direct_SelectSort(Arr, len);
for(int i = 0; i < len; i++)
{
cout<<Arr[i]<<" ";
}
cout<<endl;
return 0;
}
最后的大白话:
Direct_select 核心在于 : 遍历一遍找到最小(大)值放在最终的位置,再依次遍历剩下的子表找到最小(大)值放在最终的位置,完成排序。