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

PAT/PTA刷题实战:L1-027‘出租’题的三种解法与效率对比(C语言实现)

L1-027‘出租’题的三种解法与效率对比C语言实现当你面对PTA题库中的L1-027题时是否曾思考过如何用更高效的方式解决这个看似简单的电话号码转换问题本文将带你深入探讨三种不同的C语言实现方案从基础的冒泡排序到高级的哈希映射助你在刷题路上事半功倍。1. 问题分析与基础解法这道题的核心要求是将11位手机号码转换为两个数组一个按降序排列且不含重复数字的arr数组以及一个记录原号码每位数字在arr中位置的index数组。我们先来看最直观的解法。基础实现思路将输入字符串转换为数字数组对数字进行降序排序去除重复数字建立原数字到新数组下标的映射// 冒泡排序双指针去重实现 void bubble_sort_and_remove_duplicates(int arr[], int size) { // 冒泡排序部分 for(int i0; isize-1; i) { for(int j0; jsize-1-i; j) { if(arr[j] arr[j1]) { int temp arr[j]; arr[j] arr[j1]; arr[j1] temp; } } } // 双指针去重部分 int unique 1; for(int i1; isize; i) { if(arr[i] ! arr[i-1]) { arr[unique] arr[i]; } } }这种实现虽然直观但存在几个明显问题冒泡排序时间复杂度为O(n²)需要额外空间存储原始号码副本查找索引时需要线性搜索2. 优化解法使用标准库函数C标准库提供了高效的排序函数qsort我们可以利用它来优化排序过程。#include stdlib.h // 比较函数用于qsort int compare_desc(const void *a, const void *b) { return (*(int*)b - *(int*)a); } void qsort_solution(char *phone) { int digits[11]; for(int i0; i11; i) { digits[i] phone[i] - 0; } // 使用qsort排序 qsort(digits, 11, sizeof(int), compare_desc); // 去重并构建arr数组 int arr[10], arr_size 0; for(int i0; i11; i) { if(i0 || digits[i] ! digits[i-1]) { arr[arr_size] digits[i]; } } // 构建index数组 printf(int[] arr new int[]{); for(int i0; iarr_size; i) { printf(%d%s, arr[i], iarr_size-1?,:); } printf(};\n); printf(int[] index new int[]{); for(int i0; i11; i) { int num phone[i] - 0; for(int j0; jarr_size; j) { if(arr[j] num) { printf(%d%s, j, i10?,:); break; } } } printf(};); }性能对比指标冒泡排序法qsort法排序时间复杂度O(n²)O(nlogn)代码复杂度高中内存使用较高中等提示qsort在不同平台实现可能不同但通常采用快速排序或归并排序效率远高于冒泡排序。3. 高级解法哈希映射思想对于这种数字映射问题哈希表是最理想的数据结构。虽然C语言没有内置哈希表但我们可以利用数组模拟。void hashmap_solution(char *phone) { int digit_present[10] {0}; // 标记数字是否出现 int digit_count[10] {0}; // 记录数字出现次数 // 统计数字出现情况 for(int i0; i11; i) { int num phone[i] - 0; digit_present[num] 1; digit_count[num]; } // 构建降序arr数组 int arr[10], arr_size 0; for(int num9; num0; num--) { if(digit_present[num]) { arr[arr_size] num; } } // 构建数字到索引的映射 int num_to_index[10]; for(int i0; iarr_size; i) { num_to_index[arr[i]] i; } // 输出结果 printf(int[] arr new int[]{); for(int i0; iarr_size; i) { printf(%d%s, arr[i], iarr_size-1?,:); } printf(};\n); printf(int[] index new int[]{); for(int i0; i11; i) { int num phone[i] - 0; printf(%d%s, num_to_index[num], i10?,:); } printf(};); }三种方法对比分析特性冒泡排序法qsort法哈希映射法时间复杂度O(n²)O(nlogn)O(n)空间复杂度O(n)O(n)O(1)代码复杂度高中低适合场景教学示例一般OJ高频刷题扩展性差中好4. 实战选择与优化建议在实际刷题中选择哪种方法取决于具体场景时间紧迫时哈希映射法是最佳选择编写快速且运行高效追求代码清晰qsort法平衡了性能和可读性学习目的冒泡排序法有助于理解基础算法常见优化技巧预处理数字0-9的ASCII值避免重复计算使用位运算替代数组标记减少内存使用合并输出步骤减少I/O操作时间// 优化后的哈希映射实现 void optimized_hash_solution(char *phone) { unsigned int present 0; // 用位标记数字出现 for(int i0; i11; i) { present | 1 (phone[i]-0); } int arr[10], arr_size 0; for(int num9; num0; num--) { if(present (1num)) { arr[arr_size] num; } } int num_to_index[10]; for(int i0; iarr_size; i) { num_to_index[arr[i]] i; } // 合并输出减少printf调用 char output[256]; char *p output; p sprintf(p, int[] arr new int[]{); for(int i0; iarr_size; i) { p sprintf(p, %d%s, arr[i], iarr_size-1?,:); } p sprintf(p, };\nint[] index new int[]{); for(int i0; i11; i) { p sprintf(p, %d%s, num_to_index[phone[i]-0], i10?,:); } sprintf(p, };); printf(%s, output); }在PTA等OJ系统中这种优化可能带来10-30ms的性能提升对于大量测试用例或时间限制严格的题目尤为重要。

相关文章:

PAT/PTA刷题实战:L1-027‘出租’题的三种解法与效率对比(C语言实现)

L1-027‘出租’题的三种解法与效率对比(C语言实现) 当你面对PTA题库中的L1-027题时,是否曾思考过如何用更高效的方式解决这个看似简单的电话号码转换问题?本文将带你深入探讨三种不同的C语言实现方案,从基础的冒泡排序…...

告别卡顿!用Arduino+GRBL玩转激光雕刻,详解速度前瞻如何提升雕刻精度

告别卡顿!用ArduinoGRBL玩转激光雕刻,详解速度前瞻如何提升雕刻精度 激光雕刻机在DIY圈子里越来越火,但很多玩家都遇到过这样的尴尬:雕刻直线时光滑流畅,一到拐角就出现烧焦、停顿甚至错位。上周我的工作室接了个定制木…...

开源语音识别模型对比:SenseVoice-Small vs Whisper-Large性能与部署实测

开源语音识别模型对比:SenseVoice-Small vs Whisper-Large性能与部署实测 1. 引言:为什么需要对比语音识别模型? 语音识别技术已经成为人机交互的重要桥梁,从智能助手到会议转录,从客服系统到内容创作,无…...

避坑指南:ENSP防火墙策略配置常见错误与排查思路(附Web界面操作截图)

ENSP防火墙策略配置深度排错手册:从原理到实战的完整解决方案 当你在ENSP模拟环境中配置防火墙策略时,是否遇到过这样的场景:所有配置步骤看似正确,但流量就是无法通过?或者策略时灵时不灵,找不到规律&…...

别再死记硬背了!用这3个真实项目案例(储蓄/机票/监护系统)搞定软件工程数据流图

别再死记硬背了!用这3个真实项目案例搞定软件工程数据流图 刚接触软件工程时,你是否也对着课本上那些抽象的数据流图符号发愁?矩形、圆圈、箭头…这些看似简单的图形组合,在实际绘制时却总让人无从下手。更头疼的是考试中那些综合…...

为什么你的模型在STM32H7上崩溃了?——揭秘C语言ABI对齐、const段重定位与Flash执行冲突的3重隐性杀手

第一章:嵌入式C语言与轻量级大模型适配的底层约束全景图嵌入式系统资源受限的本质,决定了其与大模型技术融合并非简单移植,而是一场对内存、算力、确定性与工具链的系统性再平衡。C语言作为嵌入式开发的基石,在对接轻量级大模型&a…...

使用零刻mini主机/群晖/Macmini 用docker部署OpenClaw喂饭级踩坑详细教程|以及多用户多Agent对接

群晖的部署遇到挺多问题的整理下给大家一个喂饭部署教程以及一些遇到的问题总结,都是这段时间一点一点部署修改得出来的一些经验,目前整理了群晖和Mac部署的,以后有零刻再更新做零刻的部署方法 黑群晖/群晖部署 先下载文件 拉取文件 先进入s…...

SAP SD VL31N创建内向交货单,BAPI调用物料号丢失?一个隐式增强搞定

SAP SD VL31N创建内向交货单:BAPI调用物料号丢失的深度排查与隐式增强实战 最近在实施一个SAP SD模块的采购订单对接项目时,遇到了一个颇为棘手的问题:通过标准BAPI BBP_INB_DELIVERY_CREATE创建内向交货单时,物料号在传输过程中神…...

【深度解析】AUTOSAR EcuM:从启动到休眠的ECU状态管理核心

1. AUTOSAR EcuM模块的核心价值与定位 想象一下你正在驾驶一辆现代汽车,当你转动钥匙启动引擎时,仪表盘上的各种指示灯依次亮起,中控屏幕缓缓启动,空调系统开始工作——这一系列看似简单的动作背后,其实隐藏着一个复杂…...

如何利用AI Agent自动分析Linux BSP(Board Support Package)驱动和内核日志

利用AI Agent自动分析Linux BSP(Board Support Package)驱动和内核日志,是当前嵌入式开发和系统调优领域非常前沿且高回报的尝试。传统的内核调试(如排查 Kernel Panic、Oops、内存泄漏)高度依赖资深工程师的经验&…...

【仅限首批读者】Docker 27.1新增image convert命令实测报告:x86_64镜像秒级转arm64,无需重建层,性能提升92%(附压测数据)

第一章:Docker 27 跨架构镜像转换工具概览 Docker 27 引入了原生增强的跨架构镜像构建与转换能力,其核心依托于 docker buildx 的深度集成与 containerd 1.7 对多平台运行时的支持。相比早期需依赖 QEMU 模拟或手动交叉编译的方式,Docker 2…...

GraalVM原生镜像编译:探索Java应用的新编译路径

GraalVM原生镜像编译:探索Java应用的新编译路径 在Java生态系统中,编译与部署一直是开发者关注的重点。传统的Java应用依赖于JVM(Java虚拟机)来运行,这虽然提供了跨平台的便利性,但也带来了启动延迟和较高的…...

Java NIO.2 文件系统:探索高效文件操作的新维度

Java NIO.2 文件系统:探索高效文件操作的新维度 在Java编程的世界里,文件操作一直是开发者们频繁接触且至关重要的部分。随着Java版本的演进,Java NIO(New I/O)的引入为文件处理带来了革命性的变化,而Java …...

VSCode 2026协作增强实操手册:3步启用端到端加密会话、7种角色权限模板、21个企业合规审计要点

更多请点击: https://intelliparadigm.com 第一章:VSCode 2026实时协作增强概览 VSCode 2026 引入了深度集成的实时协作引擎(LiveSync Core),基于 WebRTC 与 CRDT(冲突无关复制数据类型)双协议…...

【YOLOv11】035、YOLOv11在移动端部署:NCNN与MNN实战踩坑笔记

一、从真机闪退开始说起 上周三深夜,测试同事扔过来一台Android设备,屏幕上赫然是熟悉的“App has stopped”。日志里只有一行模糊的memory allocation failure,但PC端模拟器明明跑得顺畅。这就是移动端部署的典型开场——模型在服务器上精度再高,到了真机上可能就是另一回…...

维谛ER4830/S整流模块用户手册

‌ER4830/S‌ 是一款由艾默生(EMERSON)生产的通信电源整流模块,广泛应用于电力、通信、工业等领域,主要用于将交流电转换为稳定的48V直流电,为通信设备、变电站二次回路、控制信号系统等提供可靠电源。 主要技术参数: ‌输出电压‌:DC 48V ‌额定输出电流‌:30A ‌最大…...

不只是Ping:深入理解Pingtunnel如何把TCP流量“藏”在ICMP包里

穿透防火墙的隐形通道:ICMP隧道技术深度解析 当企业防火墙严格限制TCP/UDP流量时,网络管理员常会保留ICMP协议的通行权限——毕竟ping命令是网络诊断的基础工具。正是这种"必要的仁慈",催生了一种巧妙的数据传输技术:将…...

别再死记硬背LSTM公式了!用PyTorch手写一个LSTM单元,5分钟搞懂门控机制

从零实现LSTM单元:用PyTorch代码拆解门控机制 当你第一次看到LSTM那一堆复杂的公式时,是不是感觉头大?遗忘门、输入门、输出门、细胞状态...这些概念听起来高大上,但真正动手写代码时却不知从何下手。今天我们就用PyTorch从零开始…...

【YOLOv11】034、YOLOv11在边缘设备部署:使用TensorRT加速NVIDIA Jetson平台

深夜的调试日志:当YOLOv11遇上Jetson Nano 上周三凌晨两点,实验室的Jetson Nano风扇还在嘶吼。屏幕上显示着YOLOv11的检测帧率:3.2 FPS。这个数字让人清醒——项目要求的实时检测是25 FPS。原生的PyTorch模型在边缘设备上的无力感,在这个深夜格外清晰。这不是算法问题,是…...

从FHSS到OFDMA:Wi-Fi协议演进中的核心技术变革

1. Wi-Fi协议演进简史:从"慢车道"到"信息高速公路" 1997年,当IEEE首次发布802.11标准时,最高2Mbps的传输速率在今天看来简直像蜗牛爬行。记得我第一次接触早期Wi-Fi时,下载一首MP3歌曲需要等待近10分钟&#…...

SQL注入靶场23-37关实战通关攻略

本文将展示sql注入靶场23-37关的通关思路 第二十三关(GET - 报错注入:过滤注释符,用引号闭合) 进入第二十三关发现又回到了GET参数,但是有区别,这关将#和-- qwe等等注释符加入了黑名单,屏蔽掉…...

ABAP批量导入Excel数据实战:从文件选择到数据库插入的完整流程

ABAP高效Excel数据导入:从基础实现到性能优化的完整指南 在企业级SAP系统开发中,Excel数据批量导入是每个ABAP开发者必须掌握的技能。无论是期初数据加载、日常业务数据维护,还是系统间数据交换,高效可靠的数据导入机制都能显著提…...

AI投毒情报预警 | Xinference国产推理框架遭受供应链窃密后门投毒

风险概述 北京时间4月22日16点,悬镜AI安全情报中心在Pypi官方仓库中监测到国产热门开源AI模型推理框架 Xinference 短时间内连续发布2.6.0、2.6.1及2.6.2三个版本更新,并且在这三个新版本框架源码中都检出混淆代码及高风险恶意行为。在混淆恶意代码中发现…...

NHSE:动物森友会存档编辑工具全面指南

NHSE:动物森友会存档编辑工具全面指南 【免费下载链接】NHSE Animal Crossing: New Horizons save editor 项目地址: https://gitcode.com/gh_mirrors/nh/NHSE 你是否厌倦了在《集合啦!动物森友会》中反复刷资源、等待稀有村民出现?想…...

Cursor 官宣AI新玩具:Canvas

推荐阅读 IDEA 官宣:终于可以爽用Cursor了! 重磅!前端再次被碾压,比 Cursor 更强的 AI 工具发布了! Cursor 3.1 发布:VS Code 那一套要失效了吗? 💡 前言:以前和 A…...

安全编程实践常见漏洞与防范措施

在数字化时代,软件安全已成为开发过程中不可忽视的核心问题。安全编程实践旨在通过规范代码编写方式,预防潜在漏洞,降低被攻击风险。由于开发者的疏忽或知识盲区,常见漏洞如注入攻击、缓冲区溢出等仍频繁出现。本文将聚焦三类典型…...

从malloc到memsafe_c:2026规范强制要求的4类API替换清单,不改业务逻辑也能通过ISO/IEC 17961合规审计

第一章:现代 C 语言内存安全编码规范 2026 成本控制策略在嵌入式系统、操作系统内核与高性能服务开发中,C 语言仍占据不可替代地位,但传统内存操作(如裸指针算术、未校验的 malloc 返回值、strcpy 类危险函数)已成为安…...

Linux文件系统(一):从磁盘结构到文件系统基础

目录 一、计算机存储体系 1. 从计算机到磁盘 2. 什么是磁盘 二、磁盘的物理结构 1. 磁盘组成 2. 数据写入原理 三、磁盘的存储结构 1. 扇区、磁道、柱面 2. 磁盘与数组 单磁道展开 同半径磁道展开 全盘展开 C / C 数组思维的线性化 四、磁盘寻址方式 1. CHS 寻址…...

Elasticsearch分布式原理:集群数据分布机制与分片路由全流程深度剖析

Elasticsearch分布式原理:集群数据分布机制与分片路由全流程深度剖析前言一、核心前置:分布式数据依赖的三大基础组件1.1 主节点(Master Node)1.2 数据节点(Data Node)1.3 分片与副本(Shard &am…...

揭秘论文优化新利器:书匠策AI,让降重与去AIGC痕迹变得如此简单!

在学术的浩瀚宇宙中,每一篇论文都是探索者智慧与汗水的结晶。然而,当重复率成为横亘在发表之路上的巨石,当AIGC(人工智能生成内容)的痕迹让论文显得机械而缺乏灵魂,我们该如何破局?别怕&#xf…...