标签:style blog http color os io strong 数据
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。
首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。
选择排序的交换操作介于和
次之间。选择排序的比较操作为
次之间。选择排序的赋值操作介于
和
次之间。
比较次数,比较次数与关键字的初始状态无关,总的比较次数
。交换次数
,最好情况是,已经有序,交换0次;最坏情况是,逆序,交换
次。交换次数比冒泡排序较少,由于交换所需CPU时间比比较所需的CPU时间多,
值较小时,选择排序比冒泡排序快。
原地操作几乎是选择排序的唯一优点,当方度(space complexity)要求较高时,可以考虑选择排序;实际适用的场合非常罕见。
#-*- encoding: utf-8 -*- def select_sort(st_bf): # 选择排序 for i in xrange(len(st_bf)): temp = st_bf[i] location = i # 找出剩余部分最小值 for j in xrange(i+1, len(st_bf)): if st_bf[j] < temp: temp = st_bf[j] location = j print temp, location # 移动数组 while location != i: st_bf[location] = st_bf[location-1] location -= 1 st_bf[i] = temp print st_bf st_bf = [6, 5, 3, 1, 8, 7, 2, 4, 2] print st_bf select_sort(st_bf)结果为:
>>> ================================ RESTART ================================ >>> [6, 5, 3, 1, 8, 7, 2, 4, 2] 1 3 [1, 6, 5, 3, 8, 7, 2, 4, 2] 2 6 [1, 2, 6, 5, 3, 8, 7, 4, 2] 2 8 [1, 2, 2, 6, 5, 3, 8, 7, 4] 3 5 [1, 2, 2, 3, 6, 5, 8, 7, 4] 4 8 [1, 2, 2, 3, 4, 6, 5, 8, 7] 5 6 [1, 2, 2, 3, 4, 5, 6, 8, 7] 6 6 [1, 2, 2, 3, 4, 5, 6, 8, 7] 7 8 [1, 2, 2, 3, 4, 5, 6, 7, 8] 8 8 [1, 2, 2, 3, 4, 5, 6, 7, 8] >>>
#include <iostream> using namespace std; void print (int st_bf[], size_t size){ for (size_t i = 0; i < size; i++) { cout<< st_bf[i] << " "; } cout<< endl; } void select_sort(int *st_bf, size_t size){ // 选择排序 for (size_t i = 0; i < size; i++){ int temp = st_bf[i]; // 缓存需要比较的值 size_t location = i; // 缓存最小值的位置 for (size_t j = i+1; j < size; j++){ // 找出剩余部分最小值 if (st_bf[j] < temp) { temp = st_bf[j]; location = j; } } cout << temp << " " << location << endl; // 移动数组 while (location != i){ st_bf[location] = st_bf[location-1]; location -= 1; } st_bf[i] = temp; print(st_bf, size); } } int main(){ int st_bf2[] = {6, 5, 3, 1, 8, 7, 2, 4, 2}; size_t size2 = sizeof(st_bf2)/sizeof(st_bf2[0]); select_sort(st_bf2, size2); return 0; }结果同上,不在贴出。
实际还可以优化一步,最后一步不用比较,肯定是最大的。不改了。
本文由@The_Third_Wave(Blog地址:http://blog.csdn.net/zhanh1218)原创。还有未涉及的,会不定期更新,有错误请指正。
如果你看到这篇博文时发现没有不完整,那是我为防止爬虫先发布一半的原因,请看原作者Blog。
如果这篇博文对您有帮助,为了好的网络环境,不建议转载,建议收藏!如果您一定要转载,请带上后缀和本文地址。
排序算法分析【三】:选择排序(附Python&C++代码),布布扣,bubuko.com
标签:style blog http color os io strong 数据
原文地址:http://blog.csdn.net/zhanh1218/article/details/38681463