10种常用排序算法简介

news/2024/4/29 15:14:39/文章来源:https://blog.csdn.net/li_peixiansang/article/details/136988599

常用排序算法

冒泡排序(Bubble Sort)

选择排序(Selection Sort)

插入排序(Insertion Sort)

希尔排序(Shell Sort)

归并排序(Merge Sort)

快速排序(Quick Sort)

堆排序(Heap Sort)

计数排序(Counting Sort)

桶排序(Bucket Sort)

基数排序(Radix Sort)

算法简介

接下来本文将从算法基本实现思路,时间复杂度,空间复杂度,使用情况来对10种算法一一介绍

  1. 冒泡排序(Bubble Sort):

    • 思路:依次比较相邻的元素,如果它们的顺序错误就交换位置,重复这个过程直到没有任何交换发生。
    • 时间复杂度:平均情况和最坏情况下都为O(n^2)。
    • 空间复杂度:O(1)。
    • 使用情况:适用于小型数据集的排序,效率较低,不建议用于大规模数据排序。
  2. 选择排序(Selection Sort):

    • 思路:每次从未排序的部分选择最小(或最大)的元素放到已排序部分的末尾。
    • 时间复杂度:平均情况和最坏情况下都为O(n^2)。
    • 空间复杂度:O(1)。
    • 使用情况:不稳定排序算法,适用于简单实现且不占用额外空间的情况。
  3. 插入排序(Insertion Sort):

    • 思路:将待排序的元素插入到已经排序的数组中的合适位置。
    • 时间复杂度:平均情况和最坏情况下都为O(n^2)。
    • 空间复杂度:O(1)。
    • 使用情况:适用于小型数据集或基本有序的数据集。
  4. 希尔排序(Shell Sort):

    • 思路:插入排序的改进版,通过设定一个间隔序列来进行插入排序,最终达到完全排序。
    • 时间复杂度:取决于间隔序列的选择,一般为O(n log^2 n)。
    • 空间复杂度:O(1)。
    • 使用情况:适用于中等规模的数据集,对大规模数据也有较好的表现。
  5. 归并排序(Merge Sort):

    • 思路:采用分治法,将数组分成两半分别排序,然后合并两个有序的子数组。
    • 时间复杂度:平均和最坏情况下都为O(n log n)。
    • 空间复杂度:O(n)。
    • 使用情况:稳定排序算法,适用于大规模数据集的排序。
  6. 快速排序(Quick Sort):

    • 思路:选取一个基准值,将小于基准值的放在左边,大于基准值的放在右边,然后递归处理左右两边。
    • 时间复杂度:平均情况下为O(n log n),最坏情况下为O(n^2)。
    • 空间复杂度:取决于递归的深度,在最坏情况下为O(n)。
    • 使用情况:常用的高效排序算法,对大规模数据表现良好。
  7. 堆排序(Heap Sort):

    • 思路:利用堆的性质进行排序,首先构建最大堆或最小堆,然后不断取出堆顶元素调整堆。
    • 时间复杂度:平均和最坏情况下都为O(n log n)。
    • 空间复杂度:O(1)。
    • 使用情况:不稳定排序算法,适用于需要原地排序的情况。
  8. 计数排序(Counting Sort):

    • 思路:统计数组中每个元素出现的次数,然后根据统计信息将元素放回数组。
    • 时间复杂度:O(n + k),其中k为最大元素的范围。
    • 空间复杂度:O(k)。
    • 使用情况:适用于元素范围不是很大的情况。
  9. 桶排序(Bucket Sort):

    • 思路:将元素分散到多个桶中,然后对每个桶中的元素进行排序,最后合并所有桶。
    • 时间复杂度:取决于桶的数量和每个桶内排序所用的算法。
    • 空间复杂度:O(n + k),k为桶的数量。
    • 使用情况:适用于元素均匀分布在范围内的情况。
  10. 基数排序(Radix Sort):

    • 思路:按照数字的位数从低位到高位依次进行排序,通常使用稳定的排序算法作为子排序。
    • 时间复杂度:O(d*(n+k)),其中d为数字的位数,k为基数。
    • 空间复杂度:O(n + k)。
    • 使用情况:适用于整数数据的排序,位数较少且范围不是很大的情况。

各算法特点

  • 简单排序算法:冒泡排序、选择排序、插入排序适用于小型数据集,实现简单但效率较低。

  • 改进型排序算法:希尔排序通过设置间隔序列进行插入排序,适用于中等规模数据集。

  • 分治法排序:归并排序和快速排序适用于大规模数据集,归并排序稳定且时间复杂度为O(n log n),快速排序常用且高效。

  • 堆排序:利用堆的性质进行排序,适用于需要原地排序的情况。

  • 计数排序桶排序基数排序:适用于特定范围或特定类型数据的排序,具有线性时间复杂度。

最后希望本文章能带大家初步了解各排序算法,感谢阅读

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_1027612.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在 Windows 11 上安装 MongoDB

MongoDB 是一个流行的 NoSQL 数据库,它提供了灵活的数据存储方案,而 MongoDB Compass 则是一个可视化管理工具,可以更轻松地与 MongoDB 数据库交互和管理。在本文中,我们将介绍如何在 Windows 11 上安装 MongoDB,并配置…

Radio Silence for mac 好用的防火墙软件

Radio Silence for Mac是一款功能强大的网络防火墙软件,专为Mac用户设计,旨在保护用户的隐私和网络安全。它具备实时网络监视和控制功能,可以精确显示每个网络连接的状态,让用户轻松掌握网络活动情况。 软件下载:Radio…

B2902A是德科技B2902A精密型电源

181/2461/8938产品概述: Agilent B2902A 精密源/测量单元 (SMU) 是一款 2 通道、紧凑且经济高效的台式 SMU,能够源和测量电压和电流。它用途广泛,可以轻松、高精度地执行 I/V(电流与电压)测量。4 象限源和测量功能的集…

基于SpringCloud+Hadoop+Vue实现的企业级网盘系统实现

编程语言:Java、Mybatis、Spring、SpringBoot、SpringCloud、Node、Vue 开发环境:Windows 10 Mysql 开发工具:WebStorm、IDEA编译器、Git、Maven 应用部署服务器:SpringBoot内置Tomcat插件 Node服务器:Node v10.1…

低功耗、低成本 NAS/公共文件夹 的可能性

使用现状:多台工作电脑,家里人手一台,还在两个住处 有好几台工作电脑,不同电脑不同OS有不同的用途,最大的问题就是各个电脑上文件的同步问题,这里当然就需要局域网里的公共文件夹,在NAS的问题上…

002-基于Pytorch的手写汉字数字分类

本节将介绍一种 2.1 准备 2.1.1 数据集 (1)MNIST 只要学习过深度学习相关理论的人,都一定听说过名字叫做LeNet-5模型,它是深度学习三巨头只有Yann Lecun在1998年提出的一个CNN模型(很多人认为这是第一个具有实际应用…

Qlib-Server:量化库数据服务器

Qlib-Server:量化库数据服务器 介绍 Qlib-Server 是 Qlib 的配套服务器系统,它利用 Qlib 进行基本计算,并提供广泛的服务器系统和缓存机制。通过 Qlib-Server,可以以集中的方式管理 Qlib 提供的数据。 框架 Qlib 的客户端/服务器框架基于 WebSocket 构建,这是因为 WebS…

学点儿Java_Day10_集合框架(List、Set、HashMap)

1 简介 ArrayList: 有序(放进去顺序和拿出来顺序一致),可重复 HashSet: 无序(放进去顺序和拿出来顺序不一定一致),不可重复 Testpublic void test1() {String[] array new String[3];//List: 有序 可重复//有序: 放入顺序 与 拿出顺序一致,…

【NLP笔记】大模型prompt推理(提问)技巧

文章目录 prompt概述推理(提问)技巧基础prompt构造技巧进阶优化技巧prompt自动优化 参考链接: Pre-train, Prompt, and Predict: A Systematic Survey of Prompting Methods in Natural Language Processing预训练、提示和预测:NL…

【并发】第二篇 ThreadLocal详解

导航 一. ThreadLocal 简介二. ThreadLocal 源码解析1. get2. set3 .remove4. initialValue三. ThreadLocalMap 源码分析1. 构造方法2. getEntry()3. set()4. resize()5. expungeStaleEntries()6. cleanSomeSlots()7. nextIndex()8. remove()9. 总结ThreadLocalMap四. 内存泄漏…

HarmonyOS 应用开发之显式Want与隐式Want匹配规则

在启动目标应用组件时,会通过显式 Want 或者隐式 Want 进行目标应用组件的匹配,这里说的匹配规则就是调用方传入的 want 参数中设置的参数如何与目标应用组件声明的配置文件进行匹配。 显式Want匹配原理 显式 Want 匹配原理如下表所示。 名称类型匹配…

NanoMQ的安装与部署

本文使用docker进行安装,因此安装之前需要已经安装了docker 拉取镜像 docker pull emqx/nanomq:latest 相关配置及密码认证 创建目录/usr/local/nanomq/conf以及配置文件nanomq.conf、pwd.conf # # # # MQTT Broker # # mqtt {property_size 32max_packet_siz…

使用苹果应用商店上架工具实现应用快速审核与发布

摘要 移动应用app上架是开发者关注的重要环节,但常常会面临审核不通过等问题。为帮助开发者顺利完成上架工作,各种辅助工具应运而生。本文探讨移动应用app上架原理、常见辅助工具功能及其作用,最终指出合理使用工具的重要性。 引言 移动应…

第4章.精通标准提示,引领ChatGPT精准输出

标准提示 标准提示,是引导ChatGPT输出的一个简单方法,它提供了一个具体的任务让模型完成。 如果你要生成一篇新闻摘要。你只要发送指示词:汇总这篇新闻 : …… 提示公式:生成[任务] 生成新闻文章的摘要: 任务&#x…

Stable Diffusion WebUI 生成参数:脚本(Script)——提示词矩阵、从文本框或文件载入提示词、X/Y/Z图表

本文收录于《AI绘画从入门到精通》专栏,专栏总目录:点这里,订阅后可阅读专栏内所有文章。 大家好,我是水滴~~ 在本篇文章中,我们将深入探讨 Stable Diffusion WebUI 的另一个引人注目的生成参数——脚本(Script)。我们将逐一细说提示词矩阵、从文本框或文件导入提示词,…

跑腿小程序|基于微信小程序的跑腿平台小程序设计与实现(源码+数据库+文档)

跑腿平台小程序目录 目录 基于微信小程序的跑腿平台小程序设计与实现 一、前言 二、系统设计 三、系统功能设计 1、用户信息管理 2、跑腿任务管理 3、任务类型管理 4、公告信息管理 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、…

如何安全地添加液氮到液氮罐中

液氮是一种极低温的液体,它在许多领域广泛应用,但在处理液氮时需谨慎小心。添加液氮到液氮罐中是一个常见的操作,需要遵循一些安全准则以确保操作人员的安全和设备的完整性。 选择合适的液氮容器 选用专业设计用于存储液氮的容器至关重要。…

SnapGene 5 for Mac 分子生物学软件

SnapGene 5 for Mac是一款专为Mac操作系统设计的分子生物学软件,以其强大的功能和用户友好的界面,为科研人员提供了高效、便捷的基因克隆和分子实验设计体验。 软件下载:SnapGene 5 for Mac v5.3.1中文激活版 这款软件支持DNA构建和克隆设计&…

线性代数 - 应该学啥 以及哪些可以交给计算机

AI很热,所以小伙伴们不免要温故知新旧时噩梦 - 线代。 (十几年前,还有一个逼着大家梦回课堂的风口,图形学。) 这个真的不是什么美好的回忆,且不说老师的口音,也不说教材的云山雾绕,单…

JVM(一)——内存结构

一. 前言 1、什么是 JVM? 1)定义: Java Virtual Machine - java 程序的运行环境(java 二进制字节码的运行环境) 2)好处: 一次编写,到处运行自动内存管理,垃圾回收功能数组下标越…