软件设计师“排序算法”真题考点分析——求三连
一、考点分值占比与趋势分析
综合知识题分值统计表
年份 | 考题数量 | 总分值 | 分值占比 | 考察重点 |
---|---|---|---|---|
2018 | 2 | 2 | 2.67% | 时间复杂度/稳定性判断 |
2019 | 3 | 3 | 4.00% | 算法特性对比分析 |
2020 | 2 | 2 | 2.67% | 空间复杂度要求 |
2021 | 1 | 1 | 1.33% | 算法稳定性判断 |
2022 | 3 | 3 | 4.00% | 综合特性应用 |
2023 | 2 | 2 | 2.67% | 时间复杂度计算 |
2024 | 2 | 2 | 2.67% | 分治策略应用 |
案例题分值统计表
年份 | 考题数量 | 总分值 | 分值占比 | 考察形式 | 考察重点 |
---|---|---|---|---|---|
2018 | 0 | 0 | 0% | - | - |
2019 | 1 | 5 | 6.67% | 算法填空 | 归并排序实现 |
2020 | 1 | 5 | 6.67% | 流程图补全 | 快速排序过程 |
2021 | 0 | 0 | 0% | - | - |
2022 | 1 | 5 | 6.67% | 伪代码分析 | 堆排序原理 |
2023 | 1 | 5 | 6.67% | 复杂度计算 | 算法对比 |
2024 | 1 | 5 | 6.67% | 场景应用 | 稳定排序选择 |
趋势分析:排序算法在综合知识题中保持年均2-4%的稳定分值,重点考察时间复杂度、稳定性与空间复杂度的组合判断。案例题自2019年起呈现5年4考的规律,重点考核归并排序、堆排序的具体实现和分治策略应用,2024年新增场景应用题,强调算法选择能力。
二、真题考点深入挖掘
-
时间复杂度维度:
- 高频考查O(nlogn)级算法:堆排序(2018/2022)、归并排序(2019/2024)、快速排序(2020)的对比
- 特殊场景复杂度:冒泡排序最优情况O(n)(2021)、归并排序空间复杂度O(n)(2019)
-
稳定性维度:
- 必考稳定排序判定:归并排序(2018/2023)、冒泡排序(2021)的稳定性特征
- 不稳定算法陷阱:堆排序(2018/2022)、快速排序(2020)的不稳定特性
-
空间复杂度维度:
- 原地排序要求:堆排序O(1)(2018/2022)与快速排序递归栈空间(2020)对比
- 归并排序空间消耗:案例题多次要求分析其O(n)特性(2019/2023)
-
算法策略维度:
- 分治法应用:归并排序(2019)与快速排序(2020)的分治差异
- 堆结构应用:2022年案例题要求分析堆排序的二叉树结构特征
典型命题规律:组合型题目占比达60%,如"O(nlogn)+稳定"选归并排序(2018/2023),"O(nlogn)+原地"选堆排序(2018/2022)。
三、"wwwh"简述
是什么:排序算法是将数据元素按特定顺序排列的计算方法,核心指标包括时间复杂度、空间复杂度、稳定性。
为什么:
- 时间复杂度决定算法效率(如O(n²)级算法不适用大数据量)
- 空间复杂度影响内存消耗(如归并排序需要额外存储空间)
- 稳定性保障数据业务逻辑(如电商订单按时间+金额双排序)
怎么样:
- 比较类排序:通过元素比较确定次序(冒泡/快速/堆排序)
- 非比较类排序:通过数值特征确定次序(桶/基数排序,但不在当前考点范围)
如何做:
- 判断数据规模:小数据(n≤50)可用插入排序
- 分析稳定性需求:需要稳定则排除堆/快速排序
- 评估空间限制:内存紧张时选择原地排序(堆/快速)
- 综合决策:典型场景如"大数据+稳定"用归并排序,"大数据+内存受限"用堆排序
四、真题演练与解析
题目62(第1空)
题干:要求时间复杂度O(nlogn)且稳定,应选( )
选项:A.插入排序 B.堆排序 C.快速排序 D.归并排序
解析:
- 排除法:插入排序O(n²)不满足时间要求
- 堆排序和快速排序均为不稳定算法
- 归并排序同时满足O(nlogn)和稳定
答案:D
题目29
题干:稳定的排序算法是( )
选项:A.冒泡 B.快速 C.堆 D.简单选择
解析:
- 快速排序在划分时可能改变相等元素顺序
- 堆排序在调整堆结构时破坏稳定性
- 简单选择排序跨位置交换导致不稳定
答案:A
题目63(第2空)
题干:时间复杂度O(nlogn)且空间复杂度O(1)应选( )
解析:
- 归并排序空间复杂度O(n)不符合
- 快速排序递归栈空间平均O(logn)
- 堆排序是唯一满足O(1)空间的O(nlogn)算法
答案:B
五、极简备考笔记
算法 | 时间复杂度 | 空间复杂度 | 稳定性 | 核心特征 |
---|---|---|---|---|
冒泡排序 | O(n²)/O(n)最优 | O(1) | 稳定 | 相邻元素交换 |
快速排序 | O(nlogn)平均 | O(logn) | 不稳定 | 分治+基准元素 |
堆排序 | O(nlogn) | O(1) | 不稳定 | 完全二叉树结构 |
归并排序 | O(nlogn) | O(n) | 稳定 | 分治+额外存储空间 |
插入排序 | O(n²)/O(n)最优 | O(1) | 稳定 | 适合小规模数据 |
速记要点:
- 稳快空:稳定选归并,快速要空间,堆排省内存
- 时间三强:堆/快/归都是O(nlogn)
- 特殊场景:完全有序时冒泡排序最优
六、考点记忆顺口溜
堆快归并,时间优(时间复杂度最优)
空间堆快,原地走(堆排序和快速排序是原地排序)
稳定归并,冒泡有(稳定算法代表)
选择插入,分情况(根据数据规模选择)
分治策略,归并牛(归并排序采用分治法)
二叉树形,堆结构(堆排序的树形特征)
基准元素,快速排(快速排序的核心)
相邻交换,冒泡来(冒泡排序原理)
七、多角度解答
-
知识体系角度:
排序算法属于数据结构核心模块,与树结构(堆排序)、递归思想(快速排序)、分治策略(归并排序)紧密关联。掌握排序算法有助于理解更复杂的算法设计范式。 -
命题意图角度:
真题多设计组合条件(如"O(nlogn)+稳定")来考察考生对算法特性的综合理解能力,重点检测知识体系的完整性和应用能力。 -
解题技巧角度:
采用"条件拆解法":先处理时间复杂度→再筛选空间复杂度→最后验证稳定性。遇到案例题时,先识别算法特征(如出现merge()函数即为归并排序)。 -
错误防范角度:
高频易错点包括:
- 混淆快速排序最好/平均时间复杂度(都是O(nlogn))
- 忽视递归调用栈对空间复杂度的影响
- 误判插入排序的稳定性(实际是稳定算法)
相关文章:

软件设计师“排序算法”真题考点分析——求三连
一、考点分值占比与趋势分析 综合知识题分值统计表 年份考题数量总分值分值占比考察重点2018222.67%时间复杂度/稳定性判断2019334.00%算法特性对比分析2020222.67%空间复杂度要求2021111.33%算法稳定性判断2022334.00%综合特性应用2023222.67%时间复杂度计算2024222.67%分治…...

Visual Studio 2019/2022:当前不会命中断点,还没有为该文档加载任何符号。
1、打开调试的模块窗口,该窗口一定要在调试状态下才会显示。 vs2019打开调试的模块窗口 2、Visual Studio 2019提示未使用调试信息生成二进制文件 未使用调试信息生成二进制文件 3、然后到debug目录下看下确实未生成CoreCms.Net.Web.WebApi.pdb文件。 那下面的…...

vue--ofd/pdf预览实现
背景 实现预览ofd/pdf超链接功能 业务实现 pdf的预览 实现方式: 直接使用 <iframe :src"${url}#navpanes0&toolbar0" /> 实现pdf的预览。 navpanes0 隐藏侧边栏toolbar0 隐藏顶部工具栏 使用pdf.js,代码先行: <tem…...

Python 爬虫之requests 模块的应用
requests 是用 python 语言编写的一个开源的HTTP库,可以通过 requests 库编写 python 代码发送网络请求,其简单易用,是编写爬虫程序时必知必会的一个模块。 requests 模块的作用 发送网络请求,获取响应数据。 中文文档…...

【MySQL】CRUD
CRUD 简介 CRUD是对数据库中的记录进行基本的增删改查操作 Create(创建)Retrieve(读取)Update(更新)Delete(删除) 一、新增(Create) 语法: I…...

Spring Boot微服务架构(三):Spring Initializr创建CRM项目
使用Spring Initializr创建CRM项目 一、创建项目前的准备 访问Spring Initializr网站: 打开浏览器访问 https://start.spring.io/或者直接使用IDE(如IntelliJ IDEA或Eclipse)内置的Spring Initializr功能 项目基本信息配置: Proj…...

【笔记】PyCharm 中创建Poetry解释器
#工作记录 在使用 PyCharm 进行 Python 项目开发时,为项目配置合适的 Python 解释器至关重要。Poetry 作为一款强大的依赖管理和打包工具,能帮助我们更便捷地管理项目的依赖项与虚拟环境。下面将详细记录在 PyCharm 中创建 Poetry 解释器的步骤。 前提条…...
SDL2常用函数SDL事件处理:SDL_Event|SDL_PollEvent
SDL_Event SDL_Event是个联合体,是SDL中所有事件处理的核心。 SDL_Event是SDL中使用的所有事件结构的并集。 只要知道了那个事件类型对应SDL_Event结构的那个成员,使用它是一个简单的事情。 下表罗列了所有SDL_Event的所有成员和对应类型。 Uint32typ…...
RAID技术全解析:从基础到实战应用指南
一、RAID核心概念与级别对比 1. RAID的核心目标 数据冗余:通过镜像或校验机制防止数据丢失。 性能提升:利用条带化技术实现并行读写。 存储扩展:聚合多块磁盘容量,突破单盘限制。 2. 常见RAID级别对比 RAID级别最小磁盘数容…...
word通配符表
目录 一、word查找栏代码&通配符一览表二、word替换栏代码&通配符一览表三、参考文献 一、word查找栏代码&通配符一览表 序号清除使用通配符复选框勾选使用通配符复选框特殊字符代码特殊字符代码or通配符1任意单个字符^?一个任意字符?2任意数字^#任意数字&#…...

python中的numpy(数组)
(0)numpy介绍 NumPy是Python中用于科学计算的基础库,提供高效的多维数组对象ndarray,支持向量化运算,能大幅提高数值计算效率。它集成了大量数学函数(如线性代数、傅里叶变换等),可…...
C++ 正则表达式简介
1. 正则表达式简介 正则表达式(Regular Expression,简称Regex)是一种用于匹配和处理文本的强大工具。它通过特定的符号组合形成匹配规则,常用于表单验证、文本搜索与替换、数据清洗等场景。 C11标准引入了 <regex> 头文件…...
iOS知识复习
block原理 OC block 是个结构体,内部有个一个结构体成员 专门保存 捕捉对象 Swift闭包 是个函数,捕获了全局上下文的常量或者变量 修改数组存储的内容,不需要加_block,修改数组对象本身时需要 weak原理 Weak 哈希表 (散列表&a…...

rce命令执行原理及靶场实战(详细)
2. 原理 在根源上应用系统从设计上要给用户提供一个指定的远程命令操作的接口。漏洞主要出现在常见的路由器、防火墙、入侵检测等设备的web管理界面上。在管理界面提供了一个ping服务。提交后,系统对该IP进行ping,并且返回结果。如果后台服务器并没有对…...

Fuzz 模糊测试篇JS 算法口令隐藏参数盲 Payload未知文件目录
1 、 Fuzz 是一种基于黑盒的自动化软件模糊测试技术 , 简单的说一种懒惰且暴力的技术融合了常见 的以及精心构建的数据文本进行网站、软件安全性测试。 2 、 Fuzz 的核心思想 : 口令 Fuzz( 弱口令 ) 目录 Fuzz( 漏洞点 ) 参数 Fuzz( 利用参数 ) PayloadFuzz(Bypass)…...

展示了一个三轴(X, Y, Z)坐标系!
等轴测投影”(isometric projection)风格的手绘风格三维图,即三条坐标轴(x₁, x₂, x₃)看起来彼此垂直、等角分布(通常是 120 夹角),它是常见于教材和数学书籍的 “假三维”表示法。…...

【b站计算机拓荒者】【2025】微信小程序开发教程 - chapter1 初识小程序 - 3项目目录结构4快速上手
3 项目目录结构 3.1 项目目录结构 3.1.1 目录介绍 # 1 项目主配置文件,在项目根路径下,控制整个项目的-app.js # 小程序入口文件,小程序启动,会执行此js-app.json # 小程序全局配置文件,配置小程序导航栏颜色等信息…...

LLM Tuning
Lora-Tuning 什么是Lora微调? LoRA(Low-Rank Adaptation) 是一种参数高效微调方法(PEFT, Parameter-Efficient Fine-Tuning),它通过引入低秩矩阵到预训练模型的权重变换中,实现无需大规模修改…...

云计算与大数据进阶 | 28、存储系统如何突破容量天花板?可扩展架构的核心技术与实践—— 分布式、弹性扩展、高可用的底层逻辑(下)
在上篇中,我们围绕存储系统可扩展架构详细探讨了基础技术原理与典型实践。然而,在实际应用场景中,存储系统面临的挑战远不止于此。随着数据规模呈指数级增长,业务需求日益复杂多变,存储系统还需不断优化升级࿰…...
SQL每日一练(3)
前言: 难得看到了套好题,没考我,呜呜,今日第三更! 原始表(ai生成) 1. 销售表(sales) 用途:记录每笔销售的产品 ID 及金额。 product_id(产品 …...
Axure高级交互设计:中继器嵌套动态面板实现超强体验感台账
亲爱的小伙伴,在您浏览之前,烦请关注一下,在此深表感谢!如有帮助请订阅专栏! Axure产品经理精品视频课已登录CSDN可点击学习https://edu.csdn.net/course/detail/40420 课程主题:中继器嵌套动态面板 主要内容:中继器内部嵌套动态面板,实现可移动式台账,增强数据表现…...

水利数据采集MCU水资源的智能守护者
水利数据采集仪MCU,堪称水资源的智能守护者,其重要性不言而喻。在水利工程建设和水资源管理领域,MCU数据采集仪扮演着不可或缺的角色。它通过高精度的传感器和先进的微控制器技术,实时监测和采集水流量、水位、水质等关键数据&…...
函数式编程思想详解
函数式编程思想详解 1. 核心概念 不可变数据 (Immutable Data) 数据一旦创建,不可修改。任何操作均生成新数据,而非修改原数据。 优点:避免副作用,提升并发安全,简化调试。 Java实现:使用final字段、不可变…...
SAP全面转向AI战略,S/4HANA悄然隐身
在2025年SAP Sapphire大会上,SAP首席执行官Christian Klein提出了一个雄心勃勃的愿景:让人工智能(AI)无处不在,推动企业数字化转型。SAP的AI战略核心是将AI深度融入其业务应用生态,包括推出全新版本的AI助手…...

origin绘图之【如何将横坐标/x设置为文字、字母形式】
在使用 Origin 进行科研绘图或数据可视化的过程中,我们常常会遇到这样一种需求:希望将横坐标(X轴)由默认的数字形式,改为字母(如 A、B、C……)或中文文字(如 一、二、三………...

工业智能网关建立烤漆设备故障预警及远程诊断系统
一、项目背景 烤漆房是汽车、机械、家具等工业领域广泛应用的设备,主要用于产品的表面涂装。传统的烤漆房控制柜采用本地控制方式,操作人员需在现场进行参数设置和设备控制,且存在设备智能化程度低、数据孤岛、设备维护成本高以及依靠传统人…...
cv2.VideoWriter_fourcc(*‘mp4v‘)生成的视频无法在浏览器展
看这个博主的博客,跟我碰到的问题的一致,都是使用AVC1写视频时报编码器不存在的异常,手动编译opencv-python或者使用conda install -c conda-forge opencv安装依赖即可。 博主博客:Python OpenCV生成视频无法浏览器播放问题说明及…...
MySQL 8.0 OCP 1Z0-908 161-170题
Q161.Examine this command, which executes successfully: cluster.addInstance ( ‘:’,{recoveryMethod: ‘clone’ 1}) Which three statements are true? (Choose three.) A)The account used to perform this recovery needs the BACKUP_ ADMIN privilege. B)A target i…...

Kafka Streams 和 Apache Flink 的无状态流处理与有状态流处理
Kafka Streams 和 Apache Flink 与数据库和数据湖相比的无状态和有状态流处理的概念和优势。 在数据驱动的应用中,流处理的兴起改变了我们处理和操作数据的方式。虽然传统数据库、数据湖和数据仓库对于许多基于批处理的用例来说非常有效,但在要求低延迟…...
React从基础入门到高级实战:React 基础入门 - 简介与开发环境搭建
React 简介与开发环境搭建 引言 React 是一个强大的 JavaScript 库,用于构建用户界面(UI),尤其是在单页应用(SPA)开发中表现出色。它由 Facebook(现为 Meta)开发并于 2013 年开源&…...