数据结构与算法 python--第五节 排序(二)选择排序

5 排序

5.1 冒泡排序

数据结构与算法 python–第五节 排序(一)冒泡排序

5.2 选择排序

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

选择排序的主要优点与数据移动有关。如果某个元素位于正确的最终位置上,则它不会被移动。选择排序每次交换一对元素,它们当中至少有一个将被移到其最终位置上,因此对n个元素的表进行排序总共进行至多n-1次交换。在所有的完全依靠交换去移动元素的排序方法中,选择排序属于非常好的一种。

选择排序分析

排序过程:(此处以选择最大元素为例,代码实现为选择最小元素)
在这里插入图片描述

自己初步实现的代码

def select_sort(alist):
    n = len(alist)
    for j in range(n-1):
        for i in range(j+1,n):
            if alist[j] > alist[i]:
                alist[j],alist[i] = alist[i],alist[j]

list0 = [31,23,47,81,92,56,40,55,76]
select_sort(list0)
print(list0)

纠错:自己上面实现的代码虽然也可以让元素正确顺序排列,但是里面的思想和选择排序有所不同。以上代码是相邻元素,谁小就往前放,但没有依次选择出最小的元素往前放;
选择排序要求:遍历一轮后,把最小的放最前面,然后对剩余元素再次遍历,选出最小的放在第二个位置,以此类推……
因此,听课之后的代码改正为:

实现代码(正确)

def selection_sort(alist):
    n = len(alist)
    # 需要进行n-1次选择操作
    for i in range(n-1):
        # 记录最小位置
        min_index = i
        # 从i+1位置到末尾选择出最小数据
        for j in range(i+1, n):
            if alist[min_index] > alist[j]:
                min_index = j
        alist[i], alist[min_index] = alist[min_index], alist[i]

alist = [54,226,93,17,77,31,44,55,20]
selection_sort(alist)
print(alist)

时间复杂度:

  • 最优时间复杂度:O(n2)
  • 最坏时间复杂度:O(n2)
  • 稳定性:不稳定(考虑升序每次选择最大元素的情况)
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Python 是一种高级语言,其语法简单易懂,非常适合用来实现数据结构算法。下面介绍几种常用的数据结构算法的 Python 实现。 1. 数组 在 Python 中,可以用列表(list)来实现数组。例如,以下代码实现了一个长度为 5 的整型数组: ``` arr = [0] * 5 ``` 2. 栈 栈是一种后进先出(LIFO)的数据结构,可以用 Python 的列表来实现。例如,以下代码实现了一个栈: ``` stack = [] # 初始化一个空栈 # 入栈 stack.append(1) stack.append(2) stack.append(3) # 出栈 top = stack.pop() # 弹出栈顶元素(3) ``` 3. 队列 队列是一种先进先出(FIFO)的数据结构,可以用 Python 的列表来实现。例如,以下代码实现了一个队列: ``` queue = [] # 初始化一个空队列 # 入队 queue.append(1) queue.append(2) queue.append(3) # 出队 front = queue.pop(0) # 弹出队首元素(1) ``` 4. 链表 链表是一种通过指针链接各个点的数据结构,可以用 Python 的类来实现。例如,以下代码实现了一个链表点和链表: ``` class ListNode: def __init__(self, val=0, next=None): self.val = val self.next = next class LinkedList: def __init__(self): self.head = None # 在链表末尾插入一个点 def append(self, val): if not self.head: self.head = ListNode(val) else: curr = self.head while curr.next: curr = curr.next curr.next = ListNode(val) # 删除链表中第一个值为val的点 def delete(self, val): if not self.head: return if self.head.val == val: self.head = self.head.next return curr = self.head while curr.next: if curr.next.val == val: curr.next = curr.next.next return curr = curr.next ``` 5. 递归 递归是一种通过函数调用自身来解决问题的方法,可以用 Python 的函数来实现。例如,以下代码实现了一个递归函数,计算斐波那契数列第 n 项的值: ``` def fib(n): if n == 0 or n == 1: return n return fib(n-1) + fib(n-2) ``` 6. 排序 排序是一种将数据按照指定规则进行排序算法,可以用 Python 的内置函数来实现。例如,以下代码实现了一个简单的选择排序: ``` def selection_sort(arr): n = len(arr) for i in range(n): min_idx = i for j in range(i+1, n): if arr[j] < arr[min_idx]: min_idx = j arr[i], arr[min_idx] = arr[min_idx], arr[i] ``` 以上是 Python 实现常用的数据结构算法的简单介绍,希望对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值