美文网首页
排序与搜索——选择排序

排序与搜索——选择排序

作者: 小董不太懂 | 来源:发表于2019-10-27 17:20 被阅读0次

选择排序

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下:
首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。
选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。

选择排序分析

排序过程:


我们把比较得到的最小的数字放在队首,首先把游标放在下标为0的元素这,然后依次与后面的其他数字作比较,比较到下标为3的时候,发现17比54大,那么最小值的下标0余3进行交换,但此时比较不会停止而是拿着下标的3的数字接着同剩下的数字进行比较,最后确定下标为3的是最小的,然后下标0和下标3的元素互换,同理,其他的也是如此。
代码实现:
def select_sort(li):
    n = len(li)
    for j in range(0,n-1):
        min_index = j
        for i in range(j*+1,n):
            if li[i]<li[min_index]:
                min_index = i
        li[j],li[min_index] = li[min_index],li[j]

if __name__ == '__main__':
    ali = [12,23,11,33,4,55,12,44,52,21]
    print(ali)
    select_sort(ali)
    print(ali)

时间复杂度

最优时间复杂度:O(n^2)
最坏时间复杂度:O(n^2)
稳定性:不稳定(考虑升序每次选择最大的情况)

稳定性的问题主要是升序问题:


元祖仅做标识

第一个(26,2)是不是要依次和后面的数据比较,一直比较到(26,1)发现俩一样大,但程序还是选择(26,2)大,然后接着同后面的数据比较,把(26,2)放到队尾了,然后接着遍历,最后会把(26,1)放到次尾部,故不稳定。

相关文章

  • 排序与搜索——选择排序

    选择排序 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下:首先在未排序序列中找...

  • 排序与搜索:选择排序

    选择排序 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找...

  • 排序 -- 选择/插入

    聊聊排序吧 冒泡排序 选择排序 插入排序 快速排序 归并排序 计数排序 桶排序 堆排序 本篇 选择排序与插入排序 ...

  • 前端本地实现搜索排序

    排序实现:首先有一个排序选择框(按某个属性进行排序),排序的触发方法: 搜索实现:首先有一个搜索框,输入点击触发搜...

  • Python数据结构 第五章--排序和搜索

    本章目标: (1)了解和实现顺序搜索和二分法搜索。 (2)了解和实现选择排序、冒泡排序、归并排序、快速排序、插入排...

  • 算法设计与分析——5.排序与树结构

    5.1 引言 5.2 递归与排序 5.2.1 选择排序 代码 5.1 选择排序的递归实现 代码 5.2 选择排序...

  • 简单算法之冒泡与选择排序

    冒泡排序 选择排序 冒泡排序与选择排序的时间复杂度是相同的,选择排序更像是冒泡排序的一半,注意两种排序排列方向问题

  • 选择排序-c语言描述

    选择排序分简单选择排序与堆排序两种,先介绍简单选择排序。1.简单选择排序在未排序的序列中找到最小(大)元素,存放到...

  • algorithm md

    算法思想贪心思想双指针排序快速选择堆排序桶排序荷兰国旗问题二分查找搜索BFSDFSBacktracking分治动态...

  • 3.2-选择排序-堆排序

    参考链接 选择排序:堆排序(Heap Sort) 白话经典算法系列之七 堆与堆排序 堆排序与快速排序,归并排序一样...

网友评论

      本文标题:排序与搜索——选择排序

      本文链接:https://www.haomeiwen.com/subject/cntmvctx.html