算法—选择排序
选择排序
选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
过程演示:
1 #include <stdio.h> 2 void swap(int *a,int *b) //交換兩個變數 3 { 4 int temp = *a; 5 *a = *b; 6 *b = temp; 7 } 8 void selection_sort(int arr[], int len) 9 { 10 int i,j; 11 12 for (i = 0 ; i < len - 1 ; i++) 13 { 14 int min = i; 15 for (j = i + 1; j < len; j++) //走訪未排序的元素 16 if (arr[j] < arr[min]) //找到目前最小值 17 min = j; //紀錄最小值 18 swap(&arr[min], &arr[i]); //做交換 19 } 20 } 21 22 int main() { 23 int arr[] = { 22, 34, 3, 32, 82, 55, 89, 50, 37, 5, 64, 35, 9, 70 }; 24 int len = (int) sizeof(arr) / sizeof(*arr); 25 int i; 26 selection_sort(arr, len); 27 28 for (i = 0; i < len; i++) 29 printf("%d ", arr[i]); 30 return 0; 31 }
selection_sort