Bootstrap

03.选择排序

一、题目思路

        选择排序是一种简单直观的排序算法。它的工作原理是:首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(或最大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕

外层循环:只需要排n-1个数
内层循环:比较时j从下一个数开始,直到最后一个数,记下最小值索引

二、代码实现

#include <stdio.h>

void select_sort(int *arr, int size)
{
    int i;
    int j;
    int tmp;
    int min_index = 0;
    //排n-1个位置即可
    for (i = 0; i < size - 1; i++) {
        //找未排序数组中最小元素,记下索引,用于与待排位置交换
        min_index = i;
        for (j = i+1; j < size; j++){
            if (arr[j] < arr[min_index]) {
                min_index = j;
            }    
        }

        tmp = arr[i];
        arr[i] = arr[min_index];
        arr[min_index] = tmp;
    }

    return;
}

void show(int *arr, int size)
{
    for (int i = 0; i < size; i++) {
        if (i==size-1)
            printf("%d\n", arr[i]);
        else
            printf("%d,", arr[i]);
    }
    
    return;
}

int main()
{
    int num[] = {33,5,18,1,1,2,9};
    int size = sizeof(num)/sizeof(int);

    show(num, size);
    select_sort(num, size);
    show(num, size);

    return 0;
}
排序前
33,5,18,1,1,2,9
排序后
1,1,2,5,9,18,33

;