首页 > 编程语言 >漫画:什么是选择排序算法?

漫画:什么是选择排序算法?

时间:2023-03-17 22:47:52浏览次数:55  
标签:元素 无序 区间 算法 漫画 排序

选择排序是一种简单直观的算法,今天我们聊聊选择排序的思想,代码以及复杂度

排序思想

一天,小一尘和师傅下山去了,在集市中路经一个水果摊,只见水果摊上摆着色泽基本相同但大小不一的苹果

image-20230213173955468

image-20230213174008490

image-20230213174020361

师傅答应后,小一尘就去水果摊前买苹果了

他拿了一个袋子,从众多苹果中挑了一个最大的装入袋子,然后又从剩下的苹果中挑出了最大的放入口袋,就这样挑了几个苹果然后结账

小一尘买完苹果后,走到师傅面前

image-20230213174034090

image-20230213174045866

image-20230213174059645

慧能:这其实就是选择排序的思想,选择排序就是不断地从未排序的元素中选择最大(或最小)的元素放入已排好序的元素集合中,直到未排序中仅剩一个元素为止。

买个苹果也不忘给我传授知识,一尘心里甚是感激

排序代码

image-20230213174110770

image-20230213174127248

一尘眉头一紧

心中想到:

初始时肯定给我一个无序数组

image-20230213174141782

我先从这些元素中选出一个最小的(或最大的),和第一个元素进行交换,这样第一个元素就是最小的,第一个元素位置就变成有序区间了

image-20230213174151765

同理,在剩下的无序区间选择最小的元素,将最小元素与无序区间的第一个元素进行交换,交换后原来无序区间的第一个元素就变为有序区间的最后一个元素了,有序区间递增一

image-20230213174202657

以此类推,全部元素就可以通过这样不断地选择以及交换排完序

那如何选出最小的一个元素呢?

很容易想到:先随便选一个元素假设它为最小的元素(默认为无序区间第一个元素),然后让这个元素与无序区间中的每一个元素进行比较,如果遇到比自己小的元素,那更新最小值下标,直到把无序区间遍历完,那最后的最小值就是这个无序区间的最小值

image-20230213174214088

image-20230213174227219

想到这里,一尘已经胸有成竹了,随手写出了如下代码

image-20230213174240406

image-20230213174253092

时间复杂度

image-20230213174305360

这段代码的时间复杂度不难,和冒泡排序,插入排序的非常像,一尘心里想到

image-20230213174318605

设有 n 个元素(n = arr.length)

代码执行的时间都花费在内层for循环中的比较语句和外层for循环里的交换语句

外层for循环执行 n-1 次,那么交换(swap)就执行 n-1 次,时间复杂度为O(n)

内层for循环中的比较语句执行多少次呢?

i = 0 时,比较 n - 1 次

i = 1 时,比较 n - 2 次

...

i = n-2 时,比较 1 次

则一共比较了

image-20230213174330555

image-20230213174343141

稳定性

image-20230213174354133

image-20230213174406752

image-20230213174418398

image-20230213174429007

image-20230213174439621

image-20230213174450786

一尘和师傅提着苹果走向了回家的路

更多排序算法文章

1. 漫画:什么是冒泡排序算法?

2. 漫画:什么是选择排序算法?

3. 漫画:什么是插入排序算法?

4. 漫画:什么是希尔排序算法?

5. 漫画:什么是归并排序算法?

6. 漫画:什么是快速排序算法?

7. 漫画:什么是堆排序算法?

8. 漫画:什么是基数排序算法?

9. 漫画:什么是外部排序?

10. 什么是计数排序?

11. 十大排序算法极简汇总篇

推荐阅读

下载破 2w+,在校生必看,《程序员内功修炼》第二版出炉

从双非到大厂,帅地写了一本原创PDF送给大家

一个帮你拿offer的校招网站

算法刷题路线(系统+全面)

作者简介:我是帅地,校招拿到过不少大厂offer,毕业去了腾讯研发岗,毕业半年整到人生第一个 100 万,目前专注于写大学规划 + 校招求职相关的内容,著有个人原创网站 PlayOffer

标签:元素,无序,区间,算法,漫画,排序
From: https://www.cnblogs.com/kubidemanong/p/17228486.html

相关文章

  • 漫画:什么是冒泡排序算法?
    面试官:写一个冒泡排序吧冒泡排序是一个比较经典和简单的排序算法,今天我们从从算法本身,时间复杂度以及稳定性方面来看看冒泡排序,这些方面也是研究其他排序算法的一般思......
  • 漫画:什么是插入排序算法?
    面试官:聊聊插入排序插入排序是一种比较简单直观的排序算法,适用处理数据量比较少或者部分有序的数据,今天我们来聊聊插入排序一、排序思想只见慧能拿出了一副牌,洗......
  • 漫画:什么是归并排序算法?
    归并排序是建立在归并操作的一种高效的排序方法,该方法采用了分治的思想,比较适用于处理较大规模的数据,但比较耗内存,今天我们聊聊归并排序一、排序思想一天,小一尘和慧能......
  • 漫画:什么是希尔排序算法?
    希尔排序(ShellSort)是以它的发明者DonaldShell名字命名的,希尔排序是插入排序的改进版,实现简单,对于中等规模数据的性能表现还不错一、排序思想前情回顾:漫画:什么是插入排......
  • 漫画:什么是堆排序算法?
    面试官:写一个堆排吧堆排是基于堆的一种排序算法,对于堆的了解,请看可以管理时间的二叉堆(如果对堆的插入和删除不清楚,强烈建议先看堆),今天我们聊聊堆排的思想,复杂度以及稳定......
  • 漫画:什么是快速排序算法?
    这篇文章,以对话的方式,详细着讲解了快速排序以及排序排序的一些优化。一禅:归并排序是一种基于分治思想的排序,处理的时候可以采取递归的方式来处理子问题。我弄个例子......
  • 代码随想录算法训练营Day45 动态规划
    代码随想录算法训练营代码随想录算法训练营Day45动态规划|70.爬楼梯(进阶)322.零钱兑换70.爬楼梯(进阶)题目链接:70.爬楼梯(进阶假设你正在爬楼梯。需要n 阶你才能......
  • 【LeeCode】1122. 数组的相对排序
    【题目描述】给你两个数组,​​arr1​​​ 和 ​​arr2​​​,​​arr2​​​ 中的元素各不相同,​​arr2​​​ 中的每个元素都出现在 ​​arr1​​ 中。对 ​​arr1​......
  • Qz学算法-数据结构篇(非线性结构、树)
    非线性结构非线性结构包括:二维数组,多维数组,广义表,树结构,图结构树树结构为什么需要树结构数组存储方式的分析优点:通过下标方式访问元素,速度快。对于有序数组,还可使用二分查找......
  • 使用简单算法两小时实现猎杀乌姆帕斯(Hunt the Wumpus)Python小游戏
    “HunttheWumpus”是什么?引用wiki百科:HunttheWumpus是GregoryYob于1973年开发的一款基于文本的冒险游戏。在游戏中,玩家在一系列连接的洞穴中穿行,这些洞穴排列......