七大 排序算法(一篇文章梳理)

一、引言

排序算法是计算机科学中不可或缺的一部分,它们在数据处理、数据库管理、搜索引擎、数据分析等多个领域都有广泛的应用。排序算法的主要任务是将一组数据元素按照某种特定的顺序(如升序或降序)进行排列。本文将对一些常见的排序算法进行详细的介绍和分析,包括冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序等。

二、排序算法的分类

排序算法大致可以分为以下几类:

1 比较排序

基于比较的排序算法通过比较元素的大小来决定它们的顺序。常见的比较排序算法有冒泡排序、选择排序、插入排序、归并排序、快速排序等。

2 非比较排序

非比较排序算法不依赖于元素之间的比较,而是利用一些特定的属性或规则来排序。常见的非比较排序算法有计数排序、基数排序、桶排序等。

3 稳定排序

稳定排序算法在排序过程中,如果两个元素相等,它们在排序后的相对位置不会改变。常见的稳定排序算法有冒泡排序、插入排序、归并排序等。

4 不稳定排序

不稳定排序算法在排序过程中,如果两个元素相等,它们在排序后的相对位置可能会改变。常见的不稳定排序算法有选择排序、快速排序、堆排序等。

三、常见排序算法详解

1 冒泡排序(Bubble Sort)

冒泡排序是一种简单的排序算法,它重复地遍历待排序的序列,一次比较两个相邻的元素,如果它们的顺序错误就把它们交换过来。遍历序列的工作是重复地进行直到没有再需要交换,也就是说该序列已经排序完成。

时间复杂度:O(n^2)

空间复杂度:O(1)

def bubble_sort(arr):n = len(arr)for i in range(n):for j in range(0, n - i - 1):if arr[j] > arr[j + 1]:arr[j], arr[j + 1] = arr[j + 1], arr[j]return arr

2 选择排序(Selection Sort)

选择排序是一种简单直观的排序算法。它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。

时间复杂度:O(n^2)

空间复杂度:O(1)

def selection_sort(arr):for i in range(len(arr)):min_index = ifor j in range(i+1, len(arr)):if arr[j] < arr[min_index]:min_index = jarr[i], arr[min_index] = arr[min_index], arr[i]return arr

3 插入排序(Insertion Sort)

插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

时间复杂度:O(n^2)(最坏情况)

空间复杂度:O(1)

def insertion_sort(arr):for i in range(1, len(arr)):key = arr[i]j = i - 1while j >= 0 and key < arr[j]:arr[j + 1] = arr[j]j -= 1arr[j + 1] = keyreturn arr

4 希尔排序(Shell Sort)

希尔排序是插入排序的一种更高效的改进版本,也称为缩小增量排序。它通过将待排序序列划分为若干个子序列,先对子序列进行直接插入排序,然后逐步合并子序列,最后进行一次全体记录的直接插入排序。

时间复杂度:O(n^1.3)(平均情况)

空间复杂度:O(1)

def shell_sort(arr):size = len(arr)gap = size // 2while gap > 0:for i in range(gap, size):temp = arr[i]j = iwhile j >= gap and arr[j - gap] > temp:arr[j] = arr[j - gap]j -= gaparr[j] = tempgap //= 2return arr

5 归并排序(Merge Sort)

归并排序是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。它将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。

时间复杂度:O(nlogn)

空间复杂度:O(n)

def merge_sort(arr):if len(arr) <= 1:return arrmid = len(arr) // 2left = merge_sort(arr[:mid])right = merge_sort(arr[mid:])return merge(left, right)def merge(left, right):merged = []left_index = 0right_index = 0while left_index < len(left) and right_index < len(right):if left[left_index] < right[right_index]:merged.append(left[left_index])left_index += 1else:merged.append(right[right_index])right_index += 1merged.extend(left[left_index:])merged.extend(right[right_index:])return merged

6 快速排序(Quick Sort)

快速排序是一种高效的排序算法,采用分治策略。它选择一个元素作为基准(pivot),将序列分为两部分,一部分小于基准,一部分大于基准,然后递归地对这两部分进行排序。

时间复杂度:O(nlogn)(平均情况)

空间复杂度:O(logn)(递归调用栈)

def quick_sort(arr):if len(arr) <= 1:return arrpivot = arr[len(arr) // 2]left = [x for x in arr if x < pivot]middle = [x for x in arr if x == pivot]right = [x for x in arr if x > pivot]return quick_sort(left) + middle + quick_sort(right)

7 堆排序(Heap Sort)

堆排序是一种基于堆数据结构的排序算法,它利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。

时间复杂度:O(nlogn)

空间复杂度:O(1)

def heapify(arr, n, i):largest = ileft = 2 * i + 1right = 2 * i + 2if left < n and arr[i] < arr[left]:largest = leftif right < n and arr[largest] < arr[right]:largest = rightif largest != i:arr[i], arr[largest] = arr[largest], arr[i]heapify(arr, n, largest)def heap_sort(arr):n = len(arr)# Build a maxheapfor i in range(n // 2 - 1, -1, -1):heapify(arr, n, i)# One by one extract elementsfor i in range(n - 1, 0, -1):arr[i], arr[0] = arr[0], arr[i]heapify(arr, i, 0)return arr

四、排序算法的比较与选择

选择排序算法时,需要考虑多个因素,包括时间复杂度、空间复杂度、稳定性、数据的特性等。

例如,对于小规模的数据,简单排序算法(如冒泡排序、选择排序、插入排序)可能更为合适,因为它们的实现简单且不需要额外的空间。然而,对于大规模的数据,更高效的排序算法(如快速排序、归并排序、堆排序)可能更为适合。

此外,对于某些特定类型的数据,如已经部分排序的数据或具p有特定分布的数据,某些排序算法可能具有更好的性能。

例如,对于几乎已经排序的数据,插入排序和冒泡排序可能具有更好的性能。对于大量重复元素的数据,计数排序和基数排序可能更为适合。

五、结论

排序算法是计算机科学中的重要组成部分,它们在各种应用中发挥着重要作用。了解各种排序算法的原理、特性和性能,对于有效地解决排序问题至关重要。在实际应用中,应根据具体的需求和数据的特性选择合适的排序算法

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

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

相关文章

【OpenGL】(1) 专栏介绍:OpenGL 库 | 3D 计算机图形应用 | GPGPU 计算 | 3D 建模和 3D动画 | 渲染技术介绍

&#x1f517; 《C语言趣味教程》&#x1f448; 猛戳订阅&#xff01;&#xff01;&#xff01; &#x1f4ad; 写在前面&#xff1a;本专栏主要内容是关于 3D 计算机图形技术的学习&#xff0c;重点是学习与此技术相关的 3D 实时渲染 (3D real-time rendering) 技术。我们会以…

Vue3:用vite创建Vue3项目

一、简介 vite是新一代前端构建工具&#xff0c;官网地址&#xff1a;https://vitejs.cn vite的优势如下&#xff1a; 轻量快速的热重载&#xff08;HMR&#xff09;&#xff0c;能实现极速的服务启动。对 TypeScript、JSX、CSS 等支持开箱即用。真正的按需编译&#xff0c;不…

计算机指令(Directives)和命令(Commands)的区别

Understanding the Difference Between Computer Directives and Commands (理解计算机指令和命令的区别) In the realm&#xff08;领域&#xff09; of computer programming, the terms&#xff08;措辞、术语&#xff09; ‘directives’ and ‘commands’ are commonly&a…

迪丽热巴留洋千金回国了吗

迪丽热巴&#xff0c;这个名字在近年来的娱乐圈中可谓是如雷贯耳。作为中国当红女演员&#xff0c;她的美貌与才华吸引了无数粉丝的目光。而近日&#xff0c;有关迪丽热巴留洋千金回国的消息引起了广泛的关注与讨论。 一直以来&#xff0c;迪丽热巴的留学经历被视为她人生中的一…

Rollup入门学习:前端开发的构建利器

在前端开发领域&#xff0c;构建工具对于优化项目结构和提升代码效率扮演着至关重要的角色。Rollup作为一款轻量级且功能强大的JavaScript模块打包器&#xff0c;近年来备受开发者青睐。本文将带你走进Rollup的世界&#xff0c;帮助你快速入门并掌握其核心用法。 一、Rollup简介…

Vue-02

开发者工具 安装插件&#xff0c;用于调试 Vue 应用。 https://chrome.zzzmh.cn/index 搜索 Vue &#xff0c;下载 Vue.js Devtools &#xff0c;此插件可以帮助更新信息&#xff0c;而不通过控制台更新&#xff0c;更方便调试。 注&#xff1a;安装插件后&#xff0c;记得在插…

SpringCloud-用nacos做服务注册与调用

步骤1&#xff1a;下载和安装Nacos 首先&#xff0c;你需要从Nacos的官方网站上下载并安装Nacos Server。根据你的操作系统选择合适的版本&#xff0c;并按照官方文档中的说明进行安装和配置。 步骤2&#xff1a;创建Spring Boot项目 在你喜欢的IDE中创建一个新的Spring Boot项…

抖音视频评论挖掘工具|视频批量采集软件

抖音视频评论挖掘工具——让你轻松获取大量评论数据 抖音视频评论挖掘工具是一款基于C#开发的高效、便捷的工具&#xff0c;旨在为用户提供全面的数据采集和分析服务。无论你是想了解用户对某个话题或产品的看法&#xff0c;还是想分析评论中的热点和趋势&#xff0c;这款工具都…

Ubuntu下安装Scala

前言 弄了一下终于成功装上了&#xff0c;这里对此进行一下总结 安装虚拟机 VMware虚拟机安装Ubuntu&#xff08;超详细图文教程&#xff09;_vmware安装ubuntu-CSDN博客https://blog.csdn.net/qq_43374681/article/details/129248167Download Ubuntu Desktop | Download | …

链接生成二维码(vue-qriously)

一、安装vue-qriously npm i vue-qriously -S二、全局mian.js中引入 import Vue from vue import VueQriously from vue-qriously Vue.use(VueQriously)三、使用 <template><div><qriously :value"qrData" :size"200" /></div>…

求排列的逆序数(c++题解)

题目描述 在Internet上的搜索引擎经常需要对信息进行比较&#xff0c;比如可以通过某个人对一些事物的排名来估计他&#xff08;或她&#xff09;对各种不同信息的兴趣&#xff0c;从而实现个性化的服务。 对于不同的排名结果可以用逆序来评价它们之间的差异。考虑1,2,…,n的…

HTML笔记2

11&#xff0c;路径 <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta name"viewport" content"widthdevice-width, initial-scale1.0"> <title>Document</title> <…

每日一练——二分查找

#include<stdio.h>int main() {char arr[] {1,2,3,4,5,6,7,8,9,10};int k 7;//查找kint left 0;int right sizeof(arr) / sizeof(arr[0]);int mid (left right) / 2 ; //中间元素的下标while(left<right){if&#xff08;arr[mid] < k&#xff09;{left mid …

第9章:Nginx高级应用场景《Nginx实战:从入门到精通》

随着Web技术的持续演进和业务需求的不断升级&#xff0c;Nginx早已超越了简单的Web服务器角色&#xff0c;成为了处理复杂网络请求和流量管理的多面手。在这一章中&#xff0c;我们将深入挖掘Nginx在高级应用场景中的无限潜力&#xff0c;包括构建坚如磐石的高可用性架构、实施…

源代码加密、源代码防泄漏c/c++与git服务器开发环境

源代码加密对于很多研发性单位来说是至关重要的&#xff0c;当然每家企业的业务需求不同所用的开发环境及开发语言也不尽相同&#xff0c;今天主要来讲一下c及git开发环境的源代码防泄密保护方案。 企业源代码泄密场景一、 在很多嵌入式开发企业中使用的c/c开发语言&#xff…

android开发者文档,推荐一个GitHub项目

Android相关 Android部分我就不分几大块了。直接列举&#xff0c;但是列举到的每一项都是面试经常会问到并且会延伸问的&#xff0c;所以需要深入的去研究。 四大组件有哪些&#xff0c;说出你对他们在Android系统中的作用和理解。Activity生命周期&#xff0c;A启动B两个页面…

定制你的Nginx世界:通过Dockerfile轻松修改默认首页,玩转容器化Web服务器

在云原生时代&#xff0c;Docker已成为众多开发者和运维人员手中的一把利器。借助Docker&#xff0c;我们可以快速构建、部署和运行应用程序&#xff0c;而其中的Dockerfile更是扮演着至关重要的角色&#xff0c;它如同一份详细的说明书&#xff0c;指导Docker如何构建自定义镜…

【设计模式】(二)设计模式六大设计原则

一、 设计原则概述 设计模式中主要有六大设计原则&#xff0c;简称为SOLID &#xff0c;是由于各个原则的首字母简称合并的来(两个L算一个,solid 稳定的)&#xff0c;六大设计原则分别如下&#xff1a; ​ 1、单一职责原则&#xff08;Single Responsibitity Principle&#…

除了Gamma和tome,还有哪些值得推荐的ai写ppt工具?

如果要说时下职场中最受欢迎的ai工具&#xff0c;那一定非ai写ppt莫属&#xff0c;即使用各类基于AI人工智能技术的软件&#xff0c;来帮我们直接生成ppt&#xff0c;免去制作PPT的各个中间环节&#xff0c;包括&#xff1a;梳理框架、搜集素材、搜集图片、排版美化等&#xff…

EasyRecovery数据恢复软件2024免费试用版下载

EasyRecovery数据恢复软件有免费试用版。用户可以免费下载并扫描丢失的文件&#xff0c;通过免费的扫描功能查看需要恢复的文件是否可以进行恢复。但是&#xff0c;当需要进行文件恢复操作时&#xff0c;需要付费购买相应的版本才可解锁全部功能。 此外&#xff0c;EasyRecove…