常见的排序算法及时间空间复杂度

排序算法是计算机科学中的基本算法之一,它用于将一组数据按照某种顺序进行排列。下面是一些常见的排序算法,以及它们的思想和时间空间复杂度,希望对大家有所帮助。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。

  1. 冒泡排序 (Bubble Sort)
  • 思想:通过多次比较和交换相邻的元素,将最大(或最小)的元素逐渐移到列表的末尾。

  • 时间复杂度:最坏情况下是O(n^2),平均情况下也是O(n^2)。

  • 空间复杂度:O(1)(原地排序,不需要额外空间)。

  1. 选择排序 (Selection Sort)
  • 思想:在未排序的数据中选择最小(或最大)的元素,将其放置在已排序部分的末尾。

  • 时间复杂度:最坏情况下是O(n^2),平均情况下也是O(n^2)。

  • 空间复杂度:O(1)(原地排序)。

  1. 插入排序 (Insertion Sort)
  • 思想:将待排序的元素逐个插入到已排序部分的正确位置,构建有序序列。

  • 时间复杂度:最坏情况下是O(n^2),平均情况下也是O(n^2)。

  • 空间复杂度:O(1)(原地排序)。

  1. 快速排序 (Quick Sort)
  • 思想:选择一个基准元素,将小于基准的元素放在左侧,大于基准的元素放在右侧,然后递归对左右子数组进行排序。

  • 时间复杂度:最坏情况下是O(n^2),平均情况下是O(n log n)。

  • 空间复杂度:平均情况下是O(log n),最坏情况下是O(n)。

  1. 归并排序 (Merge Sort)
  • 思想:将待排序数组分为两个子数组,分别对子数组进行排序,然后将它们合并成一个有序数组。

  • 时间复杂度:最坏情况下和平均情况下都是O(n log n)。

  • 空间复杂度:O(n)(需要额外的空间来合并子数组)。

  1. 堆排序 (Heap Sort)
  • 思想:将待排序数组构建成最大堆(或最小堆),然后逐步将堆顶元素与堆尾元素交换,调整堆结构,重复这个过程直到整个数组有序。

  • 时间复杂度:最坏情况下和平均情况下都是O(n log n)。

  • 空间复杂度:O(1)(原地排序)。

  1. 计数排序 (Counting Sort)
  • 思想:适用于非负整数的排序算法,通过统计每个元素出现的次数来进行排序。

  • 时间复杂度:最坏情况下和平均情况下都是O(n + k),其中k是非负整数的范围。

  • 空间复杂度:O(k)。

  1. 基数排序 (Radix Sort)
  • 思想:适用于整数或字符串的排序算法,将数据按位数进行排序,从最低位到最高位。

  • 时间复杂度:最坏情况下和平均情况下都是O(nk),其中k是位数。

  • 空间复杂度:O(n + k)。

这些排序算法在不同情况下有不同的优势和劣势,选择合适的排序算法取决于数据的特性、排序需求和性能要求。

相关推荐
智驱力人工智能5 分钟前
货车走快车道检测 高速公路安全治理的工程实践与价值闭环 高速公路货车占用小客车道抓拍系统 城市快速路货车违规占道AI识别
人工智能·opencv·算法·安全·yolo·目标检测·边缘计算
喵手15 分钟前
Python爬虫实战:电商实体消歧完整实战 - 从混乱店铺名到标准化知识库的工程化实现,一文带你搞定!
爬虫·python·算法·爬虫实战·零基础python爬虫教学·同名实体消除·从混乱店铺名到标准化知识库
weixin_4521595519 分钟前
C++与Java性能对比
开发语言·c++·算法
80530单词突击赢20 分钟前
C++哈希表实现:开散列与闭散列详解
算法·哈希算法·散列表
Timmylyx051823 分钟前
类欧几里得学习笔记
笔记·学习·算法
wangluoqi25 分钟前
26.2.2练习总结
算法
2301_7657031427 分钟前
C++中的工厂模式实战
开发语言·c++·算法
what丶k1 小时前
深度解析:以Kafka为例,消息队列消费幂等性的实现方案与生产实践
java·数据结构·kafka
星火开发设计1 小时前
C++ 输入输出流:cin 与 cout 的基础用法
java·开发语言·c++·学习·算法·编程·知识
We་ct1 小时前
LeetCode 289. 生命游戏:题解+优化,从基础到原地最优
前端·算法·leetcode·矩阵·typescript