C语言-选择排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言-选择排序相关的知识,希望对你有一定的参考价值。

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。 选择排序是不稳定的排序方法(比如序列[5, 5, 3]第一次就将第一个[5]与[3]交换,导致第一个5挪动到第二个5后面)。

1种
for
(int i=0; i<v.size(); i++) { int min = v[i]; int temp; int index = i; for(int j=i+1;j<v.size();j++) { if(v[j] < min) { min = v[j]; index = j; } } temp = v[i]; v[i] = min; v[index]= temp; }
2种
void
select_sort(int*a,int n) { register int i,j,min,t; for(i=0;i<n-1;i++) { min=i;//查找最小值 for(j=i+1;j<n;j++) if(a[min]>a[j]) min=j;//交换 if(min!=i) { t=a[min]; a[min]=a[i]; a[i]=t; } } }

 

以上是关于C语言-选择排序的主要内容,如果未能解决你的问题,请参考以下文章

选择排序解析 + 代码实现(C语言)

C语言练习之 选择排序

C语言选择排序法

8种面试经典!排序详解--选择,插入,希尔,冒泡,堆排,3种快排,快排非递归,归并,归并非递归,计数(图+C语言代码+时间复杂度)

C语言排序

排序算法1:选择排序-C语言实现