Python算法--排序-选择排序

一、选择排序

在数据量小的时候,对于排序,我们也可以采用选择排序(Selection sort),是一种简单直观的排序算法。

原理大致如下:首先,我们选择未排序数列的首位作为参考,然后依次用后面的元素与其进行比较,如果发现比他小(大),我们就进行交换位置处理,直到全部比对完成一轮后,再将第二个元素后面的元素依次与第二个元素进行比较,以此类推,直到全部遍历完所有的元素为止,就得到了一列有顺序的元素集合。

我们看一下网上的这个示意图:

二、编码实现

直接上 Python 编码实现如下:

# -*- coding: utf-8 -*-
# @Author  : Sai
# @Email   : 932934045@qq.com
# @File    : select_sort.py
# @Time    : 2020/8/11 14:54


def selection_sort(arr):
    '''
    选择排序
    :param arr: 待排序列表
    :return: 排序后的列表
    '''
    for i in range(len(arr) - 1):
        # 选择一个元素的索引暂作为最小数
        min_Index = i

        for j in range(i + 1, len(arr)):
            if arr[j] < arr[min_Index]:
                min_Index = j
        if min_Index != i:
            arr[i], arr[min_Index] = arr[min_Index], arr[i]
        # print(arr) # 这里我们可以打印每一轮排序后的结果,便于理解
    return arr


if __name__ == '__main__':
    arr1 = [10, 4, 5, 9, 8, 6, 0, 3, 2, 7, 1]
    print("排序前顺序为:", arr1)
    new_arr = selection_sort(arr1)
    print("排序后顺序为:", new_arr)

运行结果如下所示:

posted @ 2020-08-13 20:12  D调のSai  阅读(165)  评论(0编辑  收藏  举报