当前位置: 首页 > news >正文

十大经典排序算法简介

一 概述

     本文对十大经典排序算法做简要的总结(按常用分类方式排列),包含核心思想、时间/空间复杂度及特点。

二、比较类排序
1. 冒泡排序 (BUBBLE SORT)
思想:重复交换相邻逆序元素,像气泡上浮
复杂度:
时间:O(n^2)(最好情况O(n))
空间:O(1)
特点:简单但效率低,稳定排序
2. 选择排序 (SELECTION SORT)
思想:每次选择最小元素放到已排序末尾
复杂度:
时间:O(n^2)
空间:O(1)
特点:不稳定,交换次数少(适合小数据)
3. 插入排序 (INSERTION SORT)
思想:将未排序元素插入已排序序列的合适位置
复杂度:
时间:O(n^2)(最好情况O(n))
空间:O(1)
特点:稳定,对小规模/基本有序数据高效
4. 希尔排序 (SHELL SORT)
思想:分组插入排序(缩小增量法)
复杂度:
时间:O(n^{1.3})(依赖增量序列


http://www.mrgr.cn/news/93234.html

相关文章:

  • 【Linux跬步积累】—— 线程池详解(有源代码)
  • 选择排序算法
  • 离线地图显示
  • Redis数据结构——list
  • Redis数据结构——set
  • Java多线程与高并发专题——ConcurrentHashMap 在 Java7 和 8 有何不同?
  • C++————引用
  • 递归入手三维动态规划
  • Idea配置注释模板
  • 用CMake编译glfw进行OpenGL配置,在Visual Studio上运行
  • 图解MOE大模型的7个核心问题并探讨DeepSeekMoE的专家机制创新
  • 5年前问题的答案,如何造统计信息
  • Mybatis中的设计模式
  • 安装微软最新原版系统,配置好系统驱动并保留OOBE全新体验
  • JAVA入门——反射
  • 《Operating System Concepts》阅读笔记:p188-p199
  • 蓝桥杯C组真题——巧克力
  • Linux软件包管理
  • HTTP 黑科技
  • uniapp:小程序将base64图片字符串保存到手机相册