CSAH

选择排序

选择排序(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

相关文章:

  • 2021-06-22
  • 2020-01-30
  • 2021-09-03
  • 2021-05-13
  • 2018-02-19
  • 2019-03-15
  • 2021-11-27
猜你喜欢
  • 2021-11-27
  • 2021-09-30
  • 2019-10-08
  • 2021-11-27
  • 2022-01-08
  • 2021-10-21
  • 2021-12-02
相关资源
相似解决方案