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

PTA 编程题(C语言)-- 插入排序的三种实现方式对比

1. 插入排序的三种实现方式对比插入排序是C语言初学者必须掌握的基础算法之一也是PTA编程题中的常客。很多同学第一次接触这个算法时往往只记住了教科书上的标准实现却忽略了不同实现方式背后的设计哲学。今天我们就来深入探讨三种典型的插入排序实现不改变原数组、部分改变原数组和完全改变原数组的版本。先说说为什么需要了解不同实现方式。在实际开发中我们经常会遇到这样的场景有些情况下需要保留原始数据比如日志分析有些情况下需要节省内存比如嵌入式开发还有些情况需要兼顾性能和代码简洁性比如算法竞赛。不同的需求决定了我们需要选择不同的实现方式。举个例子假设你正在开发一个学生成绩管理系统需要实时插入新成绩并保持排序。如果采用不改变原数组的方式虽然安全但会占用双倍内存如果采用完全改变原数组的方式虽然节省空间但原始数据就丢失了。这时候理解不同实现的特点就显得尤为重要。2. 不改变原数组的实现方式2.1 输出时动态插入这种实现方式的核心思想是保持原数组不变只在输出时决定插入位置。就像我们在PTA原题中看到的代码1#include stdio.h int main() { int N,X,i,flag1; int A[10]; scanf(%d, N); for (i 0; i N; i) { scanf(%d, A[i]); } scanf(%d, X); for (i 0; i N; i) { if (flag X A[i]) { printf(%d , X); flag 0; } printf(%d , A[i]); } if (flag) printf(%d , X); return 0; }这个版本的优点很明显原数组A完全不被修改适合需要保留原始数据的场景不需要额外分配大数组内存使用更经济逻辑直观适合初学者理解插入排序的基本思想但缺点也很突出每次循环都要检查flag状态增加了条件判断的开销输出顺序和存储顺序分离调试时不太直观无法直接得到新数组只能用于即时输出场景2.2 分段输出法代码2给出了另一种不改变原数组的实现#include stdio.h int main() { int N,X,i,flag; int A[10]; scanf(%d, N); flag N; for (i 0; i N; i) { scanf(%d, A[i]); } scanf(%d, X); for (i 0; i N; i) { if (A[i] X) printf(%d , A[i]); else { flag i; break; } } printf(%d , X); for (i flag; i N; i) printf(%d , A[i]); return 0; }这个版本通过分段输出优化了性能减少了不必要的条件判断只在找到插入位置前比较提前确定插入点后直接输出后续元素无需再比较仍然保持原数组不变适合处理中等规模数据N在1000以内在PTA这类OJ系统中表现良好。我在实际测试中发现当N1000时这种实现比代码1要快15%左右。3. 部分改变原数组的实现3.1 右移插入法当我们需要真正得到一个有序数组而不仅仅是输出时代码3展示了一种优雅的解决方案#include stdio.h int main() { int N,i,X,flag; scanf(%d, N); int A[N1]; flag N; for (i 0; i N; i) { scanf(%d, A[i]); } scanf(%d, X); for (i 0; i N; i) { if (X A[i]) { flag i; break; } } for (i N; i flag; i--) { A[i] A[i-1]; } A[flag] X; for (i 0; i N1; i) { printf(%d , A[i]); } return 0; }这种实现的特点是就地操作直接在原数组上插入不需要额外输出逻辑空间高效虽然数组大小1但相比创建全新数组更节省内存可扩展性强很容易改造成完整的插入排序算法我曾在嵌入式项目中采用这种方法处理传感器数据因为嵌入式设备内存有限这种实现既能保证数据有序又不会占用过多内存。需要注意的是当数组很大时N10000元素后移的操作会变得比较耗时。4. 完全改变原数组的实现4.1 重新排序法代码4展示了一种暴力解决方案#include stdio.h int main() { int N,i,j,tmp; int A[10]; scanf(%d\n, N); for (i 0; i N; i) { scanf(%d, A[i]); } scanf(%d, A[N]); for (i 0; i N; i) { for (j i1; j N1; j) { if (A[i] A[j]) { tmp A[i]; A[i] A[j]; A[j] tmp; } } } for (i 0; i N1; i) { printf(%d , A[i]); } return 0; }虽然这种方法理论上可行但存在明显问题过度杀伤用O(n²)的排序算法解决O(n)的问题效率低下特别是当原数组已经有序时做了大量无用功破坏原始顺序完全打乱原数组可能丢失重要信息在实际开发中除非特殊情况比如同时需要去重和排序否则不建议使用这种方法。我在review新人代码时看到这种实现通常会建议重构。5. 三种实现方式的性能对比为了更直观地理解不同实现的差异我们通过一组测试数据来比较它们的性能表现实现方式时间复杂度空间复杂度是否修改原数组适用场景输出时动态插入O(n)O(1)否只需输出的场景分段输出法O(n)O(1)否中等规模数据输出右移插入法O(n)O(n)是需要获得新数组的场景重新排序法O(n²)O(n)是不推荐从实际测试来看当N10000时输出时动态插入耗时约1.2ms分段输出法耗时约0.8ms右移插入法耗时约0.5ms重新排序法耗时高达50ms6. 如何选择合适的实现方式根据我的项目经验选择插入排序实现方式时需要考虑以下几个因素数据规模小数据量N100任何方式都可以中等规模100N10000建议右移插入法大数据量N10000可能需要考虑更高效的算法内存限制嵌入式设备优先考虑右移插入法服务器环境可以灵活选择后续操作如果需要多次使用有序数组右移插入法是最佳选择如果只需要一次输出分段输出法更合适代码可维护性在团队项目中选择最容易被其他成员理解的实现方式通常右移插入法是平衡性最好的选择在PTA编程题练习中我建议同学们至少掌握前三种实现方式理解它们各自的优缺点。这不仅能帮助你在考试中选择最优解也能培养出根据不同场景选择合适算法的思维能力。

相关文章:

PTA 编程题(C语言)-- 插入排序的三种实现方式对比

1. 插入排序的三种实现方式对比 插入排序是C语言初学者必须掌握的基础算法之一,也是PTA编程题中的常客。很多同学第一次接触这个算法时,往往只记住了教科书上的标准实现,却忽略了不同实现方式背后的设计哲学。今天我们就来深入探讨三种典型的…...

ArcMap实战指南:缓冲区分析在城乡规划中的应用

1. ArcMap缓冲区分析入门:城乡规划师的必备技能 第一次接触缓冲区分析时,我也觉得这个功能听起来很抽象。直到参与了一个城中村改造项目,才真正体会到它的强大之处。简单来说,缓冲区分析就是在地图上围绕某个要素(比如…...

Flux Sea Studio 常见错误排查:从CUDA内存不足到提示词无效

Flux Sea Studio 常见错误排查:从CUDA内存不足到提示词无效 你是不是也遇到过,兴致勃勃地打开Flux Sea Studio准备大展身手,结果却被各种报错搞得一头雾水?从让人头疼的“CUDA out of memory”,到提示词输进去半天没反…...

LLVM实战:如何用Graphviz可视化你的数据流图(DFG)

LLVM实战:如何用Graphviz可视化你的数据流图(DFG) 在编译器优化和程序分析领域,数据流图(Data Flow Graph, DFG)是理解程序行为的重要工具。它清晰地展现了数据在指令间的流动路径,帮助开发者识…...

别再死记硬背了!用“数据库查询”和“信号处理”的视角,5分钟彻底搞懂Transformer的Attention机制

从数据库查询到信号滤波:用跨界思维拆解Transformer注意力机制 在咖啡馆的玻璃窗前,一位工程师正用铅笔在餐巾纸上画着奇怪的符号——左边是数据库表结构,右边是滤波器电路图。这看似毫不相关的两件事,却意外地成为了理解Transfor…...

SwiftUI 项目架构与代码组织:SwiftUI-Tutorials 项目结构深度解析

SwiftUI 项目架构与代码组织:SwiftUI-Tutorials 项目结构深度解析 【免费下载链接】SwiftUI-Tutorials A code example and translation project of SwiftUI. / 一个 SwiftUI 的示例、翻译的教程项目。 项目地址: https://gitcode.com/gh_mirrors/sw/SwiftUI-Tuto…...

如何快速获取Steam游戏完整文件清单:Onekey工具终极指南

如何快速获取Steam游戏完整文件清单:Onekey工具终极指南 【免费下载链接】Onekey Onekey Steam Depot Manifest Downloader 项目地址: https://gitcode.com/gh_mirrors/one/Onekey 还在为复杂的Steam游戏清单获取流程而烦恼吗?Onekey Steam Depot…...

2025年ejabberd发展趋势:实时通信技术的7大演进方向与创新突破

2025年ejabberd发展趋势:实时通信技术的7大演进方向与创新突破 ejabberd作为一款Robust, Ubiquitous and Massively Scalable Messaging Platform,在2025年将继续引领实时通信技术的发展潮流。这款基于Erlang/OTP的XMPP服务器凭借其卓越的性能和可扩展性…...

利用AI写教材,低查重技巧让教材编写流程事半功倍

整理教材知识点:难题待解与 AI 工具破局 整理教材知识点真是一项“精细活”,其中最大的挑战在于如何平衡和衔接各个知识点!有时我们会因为害怕遗漏重要的核心内容而感到焦虑,而有时又担心控制不好难度的梯度——小学教材的内容往…...

如何高效诊断AMD Ryzen系统问题:SMUDebugTool专业硬件调试完整指南

如何高效诊断AMD Ryzen系统问题:SMUDebugTool专业硬件调试完整指南 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址…...

Dev C++新手入门:从零开始掌握编辑、编译与运行

1. Dev C简介与环境搭建 第一次接触编程的朋友可能会被各种复杂的开发环境吓到,但Dev C绝对是入门C语言的最佳选择之一。这款轻量级的IDE(集成开发环境)安装包只有几十MB,对电脑配置要求极低,甚至十年前的旧电脑都能流…...

消息管理终极指南:Rocket.Chat消息撤回与编辑全攻略

消息管理终极指南:Rocket.Chat消息撤回与编辑全攻略 【免费下载链接】Rocket.Chat The Secure CommsOS™ for mission-critical operations 项目地址: https://gitcode.com/GitHub_Trending/ro/Rocket.Chat 在团队协作中,发送错误消息或需要修改已…...

Rocket.Chat频道管理终极指南:创建、归档与权限控制全解析

Rocket.Chat频道管理终极指南:创建、归档与权限控制全解析 【免费下载链接】Rocket.Chat The Secure CommsOS™ for mission-critical operations 项目地址: https://gitcode.com/GitHub_Trending/ro/Rocket.Chat Rocket.Chat作为一款注重数据保护的通信平台…...

Rocket.Chat API文档自动化生成:终极完整指南 [特殊字符]

Rocket.Chat API文档自动化生成:终极完整指南 🚀 【免费下载链接】Rocket.Chat The Secure CommsOS™ for mission-critical operations 项目地址: https://gitcode.com/GitHub_Trending/ro/Rocket.Chat Rocket.Chat作为一个开源的企业级通信平台…...

如何优化HyperDX前端构建速度:Webpack性能调优实战指南

如何优化HyperDX前端构建速度:Webpack性能调优实战指南 【免费下载链接】hyperdx Resolve production issues, fast. An open source observability platform unifying session replays, logs, metrics, traces and errors powered by ClickHouse and OpenTelemetry…...

收藏!教你一步步把自己伪装成AI Agent 资深架构师(小白/程序员必看)

最近刷脉脉,发现所有AI相关岗位的JD都在“卷疯了”——清一色要求“3年以上GPU集群管理经验,5年以上AI Agent落地经验”。 但只要稍微了解行业的人都知道,Agent大规模爆火也就这一年,连行业本身都还在“蹒跚学步”,哪里…...

KMS_VL_ALL_AIO:Windows与Office批量激活的终极解决方案

KMS_VL_ALL_AIO:Windows与Office批量激活的终极解决方案 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO KMS_VL_ALL_AIO是一款开源的智能激活脚本工具,专门为Windows系统…...

twitterscraper高级查询技巧:掌握Twitter搜索运算符的完整指南

twitterscraper高级查询技巧:掌握Twitter搜索运算符的完整指南 【免费下载链接】twitterscraper Scrape Twitter for Tweets 项目地址: https://gitcode.com/gh_mirrors/tw/twitterscraper twitterscraper是一款强大的Twitter数据采集工具,能够帮…...

Phi-3-mini-128k-instruct轻量级优势:3.8B参数实现13B模型推理质量实测

Phi-3-mini-128k-instruct轻量级优势:3.8B参数实现13B模型推理质量实测 1. 模型概述 Phi-3-Mini-128K-Instruct是一款仅有38亿参数的轻量级开放模型,却能在多项基准测试中达到130亿参数模型的推理质量。该模型采用Phi-3数据集训练,该数据集…...

Openfire插件开发完全教程:从零开始打造自定义功能模块

Openfire插件开发完全教程:从零开始打造自定义功能模块 Openfire是一款基于XMPP协议的开源实时协作服务器,通过插件系统可以轻松扩展其功能。本教程将带你从零开始,掌握Openfire插件的开发流程,从环境搭建到功能实现,…...

WechatRealFriends:轻松发现微信单向好友的智能检测工具

WechatRealFriends:轻松发现微信单向好友的智能检测工具 【免费下载链接】WechatRealFriends 微信好友关系一键检测,基于微信ipad协议,看看有没有朋友偷偷删掉或者拉黑你 项目地址: https://gitcode.com/gh_mirrors/we/WechatRealFriends …...

Media Player Classic - Home Cinema:Windows平台的开源媒体播放器王者

Media Player Classic - Home Cinema:Windows平台的开源媒体播放器王者 【免费下载链接】mpc-hc MPC-HCs main repository. For support use our Trac: https://trac.mpc-hc.org/ 项目地址: https://gitcode.com/gh_mirrors/mpc/mpc-hc Media Player Classic…...

Bearer报告格式详解:如何解读安全扫描结果和统计信息

Bearer报告格式详解:如何解读安全扫描结果和统计信息 【免费下载链接】bearer Code security scanning tool (SAST) to discover, filter and prioritize security and privacy risks. 项目地址: https://gitcode.com/gh_mirrors/be/bearer Bearer是一款强大…...

Unity Mod Manager终极指南:三步打造完美模组游戏体验

Unity Mod Manager终极指南:三步打造完美模组游戏体验 【免费下载链接】unity-mod-manager UnityModManager 项目地址: https://gitcode.com/gh_mirrors/un/unity-mod-manager Unity Mod Manager(简称UMM)是Unity游戏模组管理的专业解…...

【Android】Operit AI v1.10.0+11 豆包ai手机开源版 自动化手机

【Android】Operit AI v1.10.0+11 豆包ai手机开源版 自动化手机 链接:https://pan.xunlei.com/s/VOqA1qwT9mCub5BqFUZsQ1QEA1?pwdmfue# 一款强大的AI智能助手应用,不仅仅局限于聊天界面,它具有强大的工具调用能力和高度自定义的…...

bk-ci代码检查系统:全方位保障代码质量的终极指南

bk-ci代码检查系统:全方位保障代码质量的终极指南 【免费下载链接】bk-ci 蓝鲸持续集成平台(蓝盾) 项目地址: https://gitcode.com/gh_mirrors/bk/bk-ci 在软件开发过程中,代码质量直接影响项目的可维护性、稳定性和安全性。bk-ci(蓝…...

深蓝词库转换器:打破输入法壁垒的终极解决方案

深蓝词库转换器:打破输入法壁垒的终极解决方案 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 你是否曾因更换输入法而不得不放弃多年积累的个人词库&…...

Nanbeige 4.1-3B像素游戏风前端实测:像打游戏一样和AI聊天

Nanbeige 4.1-3B像素游戏风前端实测:像打游戏一样和AI聊天 1. 像素冒险聊天终端初体验 1.1 当AI对话遇上JRPG美学 打开Nanbeige 4.1-3B像素冒险聊天终端的第一眼,你会以为自己误入了某个复古RPG游戏的对话界面。整个界面采用了经典的4px像素边框装饰&…...

GoCelery部署指南:Docker容器化与Kubernetes集群管理

GoCelery部署指南:Docker容器化与Kubernetes集群管理 【免费下载链接】gocelery Celery Distributed Task Queue in Go 项目地址: https://gitcode.com/gh_mirrors/go/gocelery GoCelery是一个用Go语言实现的分布式任务队列,它提供了高效的任务处…...

2026最新AWVS/Acunetix-v25.12.25高级版更新扫描器

前言Acunetix Premium 是一种 Web 应用程序安全解决方案,用于管理多个网站、Web 应用程序和 API 的安全。集成功能允许您自动化 DevOps 和问题管理基础架构。Acunetix Premium:全面的 Web 应用程序安全解决方案Web 应用程序对于企业和组织与客户、合作伙…...