首页 > 编程语言 >排序算法 常见排序算法特性比较

排序算法 常见排序算法特性比较

时间:2024-08-21 08:58:28浏览次数:8  
标签:稳定 场景 记录 稳定性 特性 算法 排序

目录

排序的概念

排序:所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作。稳定性:假定在待排序的记录序列中,存在多个具有相同的关键字的记录,若经过排序,这些记录的相对次序保持不变,即在原序列中,r[i]=r[j],且r[i]在r[j]之前,而在排序后的序列中,r[i]仍在r[j]之前,则称这种排序算法是稳定的;否则称为不稳定的。

image-20240814133706190

内外部排序

内部排序:数据元素全部放在内存中的排序。
外部排序:数据元素太多不能同时放在内存中,根据排序过程的要求不能在内外存之间移动数据的排序。

稳定与非稳定排序

稳定排序:能够通过一些控制手段达到具有稳定性的排序

  1. 直接插入排序

  2. 冒泡排序

  3. 归并

稳定性在某些场景下需要:一场考试,可能会有相同分数出现,为了给相同分数排名,选择让先交卷的排名更高;在这种场景下,稳定性的作用就体现了.这种场景是一种对键值对<key,value>数据的排序.

不稳定排序:无法具有稳定性的排序

  1. 希尔排序

  2. 快速排序

  3. 直接选择排序

image-20240816212036038

  1. 堆排序

image-20240816212250177

改进排序的指标

  • 比较次数
  • 移动次数

图片

image-20240814133546351

image-20240814133602387

标签:稳定,场景,记录,稳定性,特性,算法,排序
From: https://www.cnblogs.com/DSCL-ing/p/18365073

相关文章

  • php多维数组排序 array_multisort
    参考文章:https://www.cnblogs.com/ivy-zheng/p/12557645.htmlarray_multisort — 对多个数组或多维数组进行排序array_multisort() 可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。关联(string)键名保持不变,但数字键名会被重新索引返回值成功时返......
  • 排序算法 排序性能测试代码(随机数调整,高精度时间) - C++
    目录测试工具源码testsort测试工具C++11标准库<chrono>中高精度计时器,时间精度可以达到1纳秒.C++11标准库<random>中随机数生成器,可以实现各类随机数,本测试主要用于实现9成随机数下排序性能源码源码我拆分成两部分,一部分为测试,一部分为sort源码.合并一起使用test......
  • 密码学之哈希算法
    文章目录1.哈希函数概述1.1哈希函数的定义1.2哈希函数的重要性2.SHA系列算法简介2.1SHA系列的发展历史2.2SHA系列的应用场景3.主要SHA算法详解3.1MD5算法3.2SHA-1算法3.3SHA-2算法家族3.4SHA-3算法4.SHA算法的安全性分析4.1安全性的重要性4.2已知的攻击......
  • 密码学之RSA算法
    文章目录1.RSA算法介绍1.2算法历史与发展1.3算法应用场景2.RSA密钥生成2.1选择素数2.2计算公钥和私钥2.3密钥长度与安全性3算法原理3.1加密原理3.2加密方法3.3加密示例3.4代码实现4.总结1.RSA算法介绍1.2算法历史与发展RSA算法由RonRivest、Adi......
  • Manacher 算法
    引入:万恶的字符串问题你是否看到字符串就感到迷茫而无所适从?你是否看到“border”“回文”等字眼就感到大脑宕机只会暴力?如果你像我一样有这种症状,不妨一起来学习一下Manacher算法。当你掌握了Manacher之后,你会发现,很多字符串问题都变成了板子,而你再也不用担心因为字符串抱......
  • codetop算法
    15.三数之和复杂度显然不能暴力,卡1e9思路先排序,左边固定一个i,双指针,两边开始夹逼接近-nums[i]注意,如何跳过重复的数3.无重复字符的最长子串这个思路一定要熟练215.数组中的第K个最大元素回忆下写法53.最大子数组和基本不太会写dp究竟有什么特征?答案(定义)就......
  • 一文讲清楚算法刷题-计算机专业新生必看
    哈喽,大家好,我是Sunny,你也可以叫我萨宁,一个热爱分享编程知识的程序员。我的昵称是Sunny不要停,寓意是美好的晴朗日子不要停下来,希望大家都能每天开开心心的。我的频道主要分享编程知识,生活,大学计算机学科学习,考研经验。目前已经上岸某211计算机专业,有大学学习,考研相关的问题,欢迎关......
  • 基于RNN的交通流量预测算法及Python实现
    一、算法原理RNN(循环神经网络)的算法原理主要基于其能够处理序列数据的能力,通过引入循环连接来捕捉数据中的时序依赖性。以下是RNN算法原理的详细解释:1、基本概念序列数据:如文本、语音、视频等,这些数据具有时间顺序性,即后续数据依赖于前面的数据。循环连接:RNN中的神经元不仅......
  • 基于LSTM的交通流量预测算法及Python实现
    一、算法原理LSTM(长短期记忆网络)算法原理主要涉及到一种特殊的循环神经网络(RNN)结构,旨在解决传统RNN在处理长序列数据时容易出现的梯度消失或梯度爆炸问题。LSTM通过引入三个关键的门控机制(遗忘门、输入门、输出门)以及一个细胞状态,来更有效地处理和记忆序列数据中的长期依赖关......
  • 基于GRU的交通流量预测算法及Python实现
    一、算法原理GRU(GatedRecurrentUnit,门控循环单元)算法是一种循环神经网络(RNN)的变种,旨在解决传统RNN在处理长序列时容易出现的梯度消失或梯度爆炸问题。以下是GRU算法原理的详细解析:1、基本原理GRU通过引入门控机制来控制信息的流动,使得网络能够更好地捕捉序列数据中的长期......