直接从待排序数组里选择一个最小(或最大)的数字,每次都拿一个最小数字出来,

顺序放入新数组,直到全部拿完

再简单点,对着一群数组说,你们谁最小出列,站到最后边

然后继续对剩余的无序数组说,你们谁最小出列,站到最后边

再继续刚才的操作,一直到最后一个,继续站到最后边,现在数组有序了,从小到大

举例

先说看每步的状态变化,后边介绍细节。

现有无序数组[6 2 4 1 5 9]

第一趟找到最小数1,放到最前边(与首位数字交换)

交换前:| 6 | 2 | 4 | 1 | 5 | 9 |

交换后:| 1 | 2 | 4 | 6 | 5 | 9 |

第二趟找到余下数字[2 4 6 5 9]里的最小数2,与当前数组的首位数字进行交换,实际没有交换,本来就在首位

交换前:| 1 | 2 | 4 | 6 | 5 | 9 |

交换后:| 1 | 2 | 4 | 6 | 5 | 9 |

第三趟继续找到剩余[4 6 5 9]数字里的最小数4,实际没有交换,4待首位置无须交换

第四趟从剩余的[6 5 9]里找到最小数5,与首位数字6交换位置

交换前:| 1 | 2 | 4 | 6 | 5 | 9 |

交换后:| 1 | 2 | 4 | 5 | 6 | 9 |

第五趟从剩余的[6 9]里找到最小数6,发现它待在正确的位置,没有交换

排序完毕输出正确结果[1 2 4 5 6 9]

第一趟找到最小数1的细节

当前数组是| 6 | 2 | 4 | 1 | 5 | 9 |

先把6取出来,让它扮演最小数

当前最小数6与其它数一一进行比较,发现更小数就交换角色

当前最小数6与2比较,发现更小数,交换角色,此时最小数是2,接下来2与剩余数字比较

当前最小数2与4比较,不动

当前最小数2与1比较,发现更小数,交换角色,此时最小数是1,接下来1与剩余数字比较

当前最小数1与5比较,不动

当前最小数1与9比较,不动,到达末尾

当前最小数1与当前首位数字进行位置交换,如下所示

交换前:| 6 | 2 | 4 | 1 | 5 | 9 |

交换后:| 1 | 2 | 4 | 6 | 5 | 9 |

完成一趟排序,其余步骤类似

C语言代码:

 
  1. #include <stdio.h> 
  2. int main() 
  3.     int a[5]={5,4,3,2,1},i; 
  4.   
  5.     printf("原本的数字为:"); 
  6.      for(i=0;i<5;i++) 
  7.     { 
  8.         printf("%d ",a[i]); 
  9.     } 
  10.     printf("\n"); 
  11.   
  12.     void choose (int a[],int n); 
  13.     choose (a,5); 
  14.   
  15.     printf("选择法排序后:"); 
  16.     for(i=0;i<5;i++) 
  17.     { 
  18.         printf("%d ",a[i]); 
  19.     } 
  20.     return 0; 
  21.   
  22. //选择法 
  23. void choose (int a[],int n) 
  24.     int i,j,k,temp; 
  25.     for(i=0;i<n-1;i++) 
  26.     { 
  27.         k=i;//给记号赋值 
  28.         for(j=i+1;j<n;j++) 
  29.         { 
  30.             if (a[k]>a[j]); 
  31.             { 
  32.             k=j;//使k总是指向最小元素 
  33.             } 
  34.             if (i!=k)//当k!=i时才交换 
  35.             { 
  36.                 temp=a[i]; 
  37.                 a[i]=a[k]; 
  38.                 a[k]=temp; 
  39.             } 
  40.         } 
  41.     } 

引用: