2.1 选择排序之直接选择排序

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 核心在于 : 遍历一遍找到最小(大)值放在最终的位置,再依次遍历剩下的子表找到最小(大)值放在最终的位置,完成排序。

猜你喜欢

转载自blog.csdn.net/zxj820/article/details/80426619