五分钟小知识:为什么要分稳定排序和非稳定排序?

简介: 本文主要为大家讲解一下稳定排序和非稳定排序的相关知识。

原文链接

小史是一个应届生,虽然学的是电子专业,但是自己业余时间看了很多互联网与编程方面的书,一心想进BAT互联网公司。
image.png

今天他去了一家互联网小巨头公司面试了。


没想到面试并不像想象中的顺利。

image.png


【遇见吕老师】

image.png
image.png
image.png


【面试现场】


image.png
image.png
image.png
image.png
image.png
image.png
image.png


小史:原始数据,a2和a4的位置都是3。对于稳定排序来说,排序后的序列,a2一定还是在a4前面。但是对于非稳定排序来说,就不一定了,可能排完序之后,a4反而在a2的前面了。

image.png
image.png
image.png


题目:既然最后都是有序序列,为什么还要分稳定和非稳定的排序呢?

image.png


半分钟过去了。

image.png
image.png
image.png
image.png


【请教大神】

image.png
image.png
image.png

吕老师:笔试主要问是什么,而面试主要问为什么。


image.png
image.png
【吕老师的课】

吕老师一上课就把问题抛了出来。

image.png



话音刚落,蛋哥就站了起来。


image.png


蛋哥:咱们每次考试完成后,都会按照分数进行排序。分高的自然就是第一名。分数相同的同学怎么办呢?那就是按照上次的分数来分高低。上次分高的排在前面。


image.png


蛋哥:这个时候就应该用稳定排序,在上次排好序的序列上,再针对这次的分数进行排序。稳定排序的结果能保证这次相同分数的人,上次分高的在前面。


image.png


蛋哥:再比如我们班的同学,已经按照学号排好序了。现在要按照身高排序。如果是稳定排序排好之后,身高相同的同学,还是按照学号顺序的。


image.png


吕老师:没错,其实就是有两个排序关键字的时候,稳定排序可以让第一个关键字排序的结果服务于第二个关键字排序中数值相等的那些数。


小史听完后,觉得很惭愧,其实这些场景自己也遇到过,早该想到的。


【课后】
课后小史又找到吕老师。
**
image.png
image.png

**
吕老师:你看的东西很多,是你学到了很多知识。但是这些知识之间的关联,需要你进行深入思考才能得到的。找到知识之间的联系,找到知识和实际场景之间的联系,多想想为什么,才能做到融会贯通。

来源 | 五分钟学算法
作者 | 程序员小吴

相关文章
|
6月前
|
存储 索引
线性表你还不知道原理?给老王整的明明白白
线性表你还不知道原理?给老王整的明明白白
85 0
|
算法
【算法竞赛进阶指南】程序自动分析(并查集判冲突+离散化)
【算法竞赛进阶指南】程序自动分析(并查集判冲突+离散化)
128 0
|
算法 C++
数据结构-第三章-循环顺序队-增设标记法实现各种基本功能
数据结构-第三章-循环顺序队-增设标记法实现各种基本功能
848 0
|
编译器
合并两个有序单链表,对象析构这一着我实在没想到。
合并两个有序单链表,对象析构这一着我实在没想到。
94 0
|
算法 测试技术
经典问题:移动零 | 是0就得往后挪~
这是一道LeetCode经典题目“移动零”。
213 0
|
机器学习/深度学习
1706. 球会落何处 : 简单模拟题
1706. 球会落何处 : 简单模拟题
|
SQL 存储 关系型数据库
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(下)
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(下)
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(下)
|
存储 NoSQL 关系型数据库
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(上)
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(上)
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(上)
|
存储 关系型数据库 MySQL
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(中)
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(中)
索引很难么?带你从头到尾捋一遍MySQL索引结构,不信你学不会!(中)
|
Windows
班里新来的交换生
班里新来的交换生
98 0