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

从ZZULIOJ到LeetCode:数组合并的“双指针”套路,一篇就够(附C/Java/Python三语实现)

从双指针到多语言实现有序数组合并的通用解法精要合并有序数组是算法学习中的经典问题也是技术面试中的高频考点。无论是ZZULIOJ这类在线判题系统还是LeetCode等面试准备平台都将其作为考察基础算法能力的重要题型。本文将深入探讨双指针法在合并有序数组中的应用并给出C、Java、Python三种语言的实现方案帮助开发者掌握这一核心算法技巧。1. 理解问题本质与双指针思想合并两个有序数组的核心在于如何高效地将两个已经排序的数组合并为一个新的有序数组。最直观的解法可能是先将两个数组合并然后重新排序但这种方法的时间复杂度为O((mn)log(mn))显然不是最优解。双指针法提供了一种O(mn)时间复杂度的解决方案。其基本思想是初始化两个指针分别指向两个数组的起始位置比较两个指针所指元素的大小将较小的元素放入结果数组移动较小元素所在数组的指针重复上述过程直到某个数组遍历完成将剩余未遍历的元素直接追加到结果数组中对于ZZULIOJ 1124题的特殊情况——一个升序一个降序的数组合并我们需要对标准双指针法进行适当调整// C语言处理升序降序合并的核心逻辑 while(i m j n) { if(a[i] b[j]) { c[k] a[i]; } else { c[k] b[j]; } }2. 不同排序方向的处理策略在实际问题中我们可能遇到各种排序方向的组合。以下是三种常见情况及其处理策略情况数组A顺序数组B顺序处理策略1升序升序双指针从头开始2降序降序双指针从头开始3升序降序A指针从尾开始B指针从头开始对于第三种情况如ZZULIOJ 1124题关键调整在于升序数组的指针应从末尾开始最大元素降序数组的指针应从开头开始也是最大元素比较两个指针所指元素选择较大的放入结果数组3. 多语言实现对比3.1 C语言实现C语言的实现注重效率和内存控制适合嵌入式或性能敏感场景#include stdio.h #define MAX_SIZE 1000000 int a[MAX_SIZE], b[MAX_SIZE]; int main() { int m, n; scanf(%d, m); for(int i 0; i m; i) scanf(%d, a[i]); scanf(%d, n); for(int i 0; i n; i) scanf(%d, b[i]); int i m - 1, j 0, k 0; int c[m n]; while(i 0 j n) { if(a[i] b[j]) { c[k] a[i--]; } else { c[k] b[j]; } } while(i 0) c[k] a[i--]; while(j n) c[k] b[j]; for(int i 0; i m n; i) { printf(%d , c[i]); } return 0; }3.2 Java实现Java版本更注重面向对象和异常处理适合企业级应用import java.util.Scanner; public class MergeSortedArrays { public static void main(String[] args) { Scanner sc new Scanner(System.in); int m sc.nextInt(); int[] a new int[m]; for(int i 0; i m; i) a[i] sc.nextInt(); int n sc.nextInt(); int[] b new int[n]; for(int i 0; i n; i) b[i] sc.nextInt(); int[] result mergeArrays(a, b); for(int num : result) { System.out.print(num ); } } public static int[] mergeArrays(int[] a, int[] b) { int m a.length, n b.length; int[] c new int[m n]; int i m - 1, j 0, k 0; while(i 0 j n) { if(a[i] b[j]) { c[k] a[i--]; } else { c[k] b[j]; } } while(i 0) c[k] a[i--]; while(j n) c[k] b[j]; return c; } }3.3 Python实现Python版本简洁明了适合快速原型开发和算法验证def merge_sorted_arrays(): m, *a map(int, input().split()) n, *b map(int, input().split()) i, j m - 1, 0 result [] while i 0 and j n: if a[i] b[j]: result.append(a[i]) i - 1 else: result.append(b[j]) j 1 result.extend(reversed(a[:i1])) result.extend(b[j:]) print( .join(map(str, result))) merge_sorted_arrays()4. 性能分析与优化技巧双指针法的基本时间复杂度已经是理论最优但仍有一些优化空间内存预分配在C/C中预先分配足够大的数组避免动态扩容开销循环展开对于特别大的数组可以考虑手动循环展开以减少分支预测失败并行比较在某些架构下可以使用SIMD指令并行比较多个元素边界检查消除对于性能关键代码可以移除不必要的边界检查提示在面试中除了写出正确代码外能够分析算法复杂度并提出优化方向同样重要。对于不同语言性能考量点也有所不同C/C关注内存访问模式和缓存利用率Java注意自动装箱拆箱和垃圾收集的影响Python尽量使用内置函数和列表推导式避免显式循环5. 常见变体与解题思路合并有序数组问题有多种变体掌握核心思想后可以举一反三合并K个有序数组使用优先队列堆来扩展双指针思想原地合并如LeetCode 88题要求不额外使用空间去重合并在合并过程中跳过重复元素非整数数组合并处理浮点数或字符串等类型的比较以原地合并为例关键技巧是从后向前填充避免覆盖未处理的元素public void merge(int[] nums1, int m, int[] nums2, int n) { int i m - 1, j n - 1, k m n - 1; while(i 0 j 0) { nums1[k--] nums1[i] nums2[j] ? nums1[i--] : nums2[j--]; } while(j 0) { nums1[k--] nums2[j--]; } }6. 实际应用场景与经验分享合并有序数组的算法在真实开发中有广泛应用数据库系统合并多个有序结果集搜索引擎合并倒排索引的发布列表大数据处理MapReduce中的归并阶段版本控制系统合并不同分支的修改在实现这类算法时容易犯的几个错误包括指针移动方向错误特别是在处理不同排序方向的数组时边界条件处理不完整如一个数组为空的情况结果数组空间分配不足忽略输入数据的有效性检查我在实际项目中曾遇到过因忽略输入验证而导致的问题一个看似简单的数组合并函数由于没有检查输入数组是否确实有序在某些边界情况下产生了错误结果。这提醒我们即使是基础算法也要考虑鲁棒性。

相关文章:

从ZZULIOJ到LeetCode:数组合并的“双指针”套路,一篇就够(附C/Java/Python三语实现)

从双指针到多语言实现:有序数组合并的通用解法精要 合并有序数组是算法学习中的经典问题,也是技术面试中的高频考点。无论是ZZULIOJ这类在线判题系统,还是LeetCode等面试准备平台,都将其作为考察基础算法能力的重要题型。本文将深…...

边缘网络:构建边缘计算的网络基础设施

边缘网络:构建边缘计算的网络基础设施 一、边缘网络概述 1.1 边缘网络的定义 边缘网络是指部署在网络边缘的网络基础设施,它将计算、存储和网络资源扩展到离用户更近的位置。边缘网络支持低延迟数据处理、实时响应和分布式计算,是边缘计算的关…...

CANN/asc-devkit Mull乘法溢出API

Mull 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。 项目地址: https://gitcode.com/cann/…...

drf-nested-routers测试指南:确保嵌套路由稳定性的完整方案

drf-nested-routers测试指南:确保嵌套路由稳定性的完整方案 【免费下载链接】drf-nested-routers Nested Routers for Django Rest Framework 项目地址: https://gitcode.com/gh_mirrors/dr/drf-nested-routers drf-nested-routers是Django Rest Framework的…...

Lusca源码解析:深入理解Express安全中间件的实现原理

Lusca源码解析:深入理解Express安全中间件的实现原理 【免费下载链接】lusca Application security for express apps. 项目地址: https://gitcode.com/gh_mirrors/lu/lusca Lusca是一款专为Express应用设计的安全中间件,它集成了多种安全防护机制…...

Ormar 性能优化:10 个提升数据库查询效率的技巧

Ormar 性能优化:10 个提升数据库查询效率的技巧 【免费下载链接】ormar python async orm with fastapi in mind and pydantic validation 项目地址: https://gitcode.com/gh_mirrors/or/ormar Ormar 是一个专为 FastAPI 设计的 Python 异步 ORM,…...

暗黑破坏神2存档修改器:释放你的游戏创造力

暗黑破坏神2存档修改器:释放你的游戏创造力 【免费下载链接】diablo_edit Diablo II Character editor. 项目地址: https://gitcode.com/gh_mirrors/di/diablo_edit 你是否曾想过,如果能让暗黑破坏神2中的角色拥有完美的装备组合?如果…...

深度解析Py-ART雷达数据处理:从数据校正到高级反演的全流程实战

深度解析Py-ART雷达数据处理:从数据校正到高级反演的全流程实战 【免费下载链接】pyart The Python-ARM Radar Toolkit. A data model driven interactive toolkit for working with weather radar data. 项目地址: https://gitcode.com/gh_mirrors/py/pyart …...

git讲解,git vscode 对应,git pycharm 对应

文章目录安装git配置git什么是git 仓库创建版本库git addvscodegit statusgit addgit statuspycharm变更列表视图如果创建文件的时候选择了添加到git版本控制暂存区域视图时光穿梭机版本回退修改文件vscodepycharm变更列表暂存区域git logvscodepycharmgit reset 版本回退git r…...

D1021UK,125W高功率输出的推挽式DMOS RF FET射频晶体管

简介今天我要向大家介绍的是 TT Electronics/Semelab 的金金属化多用途硅DMOS RF FET晶体管——D1021UK。这是一款专为HF/VHF/UHF通信频段(1 MHz至400 MHz)设计的推挽式(Push-Pull)射频功率场效应管,在28V工作电压下可…...

百度网盘Mac版SVIP破解终极指南:三步解锁高速下载限制

百度网盘Mac版SVIP破解终极指南:三步解锁高速下载限制 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 还在为百度网盘Mac版的龟速下载而烦恼…...

D1016UK,1MHz至1GHz宽带适用的低噪声高效率射频功率晶体管

简介今天我要向大家介绍的是 TT Electronics/Semelab 的DMOS RF FET晶体管——D1016UK。这是一款专为VHF/UHF通信频段(1 MHz至1GHz)设计的金金属化多用途硅RF功率场效应管,采用推挽式架构,在28V工作电压下可提供40W的输出功率。作…...

对服务器网络参数具体相关概念

你问到了 高并发系统真正的“全链路瓶颈” 问题,非常关键! 要真正理解“一个请求从用户到服务器再返回”到底经历了什么、哪里可能卡住,确实不能只看 CPU —— 网卡、网络带宽、协议开销、包大小、运营商、甚至流量套餐,都会影响整…...

MyBatis-Plus详解(速成版)

一、介绍MyBatis-Plus: 1.概念 MyBatis-Plus 是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 MyBatis-Plus的官网简介:https://baomidou.com/introduce/ 2.特点: 无侵入&#xff…...

告别VS Code!用CLion 2024.3 + CUDA 12.1搭建高效GPU开发环境(附CMake配置避坑指南)

CLion 2024.3 CUDA 12.1:打造专业级GPU开发环境的终极指南 在GPU加速计算领域,开发者长期面临一个两难选择:是使用功能全面但笨重的Visual Studio,还是选择轻量灵活但功能有限的VS Code?JetBrains CLion 2024.3的出现…...

VSCode里Code Runner跑Python总报9009?别慌,检查一下你的setting.json文件

VSCode中Code Runner执行Python报错9009的终极排查指南 当你第一次在VSCode中用Code Runner插件运行Python脚本,满心期待看到输出结果时,终端却弹出"Process exited with code 9009"的红色错误提示——这种挫败感我深有体会。这个看似神秘的错…...

163MusicLyrics:免费解锁网易云QQ音乐歌词,告别本地音乐“哑巴“时代

163MusicLyrics:免费解锁网易云QQ音乐歌词,告别本地音乐"哑巴"时代 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 还在为本地音乐播放…...

Pearcleaner:Mac应用彻底清理的终极解决方案,告别数字垃圾困扰

Pearcleaner:Mac应用彻底清理的终极解决方案,告别数字垃圾困扰 【免费下载链接】Pearcleaner A free, source-available and fair-code licensed mac app cleaner 项目地址: https://gitcode.com/gh_mirrors/pe/Pearcleaner 还在为Mac应用卸载后残…...

AutoSar网络管理(NM)与0x28通信控制服务:搞懂主从节点,精准控制子总线流量

AutoSar网络管理中0x28服务的拓扑控制艺术:主从架构与子总线流量精准调度 在车载电子系统日益复杂的今天,一条CAN总线上可能挂着十几个ECU节点,而网关则需要管理多条这样的总线。想象一下,当某个子总线上的节点需要软件更新时&…...

技术解密:如何从零构建开源贴片机的完整指南

技术解密:如何从零构建开源贴片机的完整指南 【免费下载链接】lumenpnp The LumenPnP is an open source pick and place machine. 项目地址: https://gitcode.com/gh_mirrors/lu/lumenpnp 在电子制造领域,贴片机一直是小型创客和硬件开发者难以企…...

mat-chem-sim-pred开发者指南:如何贡献新的科学计算算子

mat-chem-sim-pred开发者指南:如何贡献新的科学计算算子 【免费下载链接】mat-chem-sim-pred 面向工业领域,聚焦计算仿真、预测两大核心场景,构建面向流程工业"机理数据"双轮驱动的领域计算层,推动AI for Science在材料…...

AI大模型Agent面试,超详细(附答案)!

AI大模型Agent面试,超详细(➕答案)!假如你从2026年开始学大模型,按这个步骤走准能稳步进阶。 接下来告诉你一条最快的邪修路线, 3个月即可成为模型大师,薪资直接起飞。阶段1:大模型基础阶段2:RA…...

三步搞定Windows和Office永久激活:KMS_VL_ALL_AIO智能激活全攻略

三步搞定Windows和Office永久激活:KMS_VL_ALL_AIO智能激活全攻略 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统频繁弹出激活提示而烦恼吗?Office突然…...

终极AMD Ryzen调试指南:简单三步掌握硬件性能调优

终极AMD Ryzen调试指南:简单三步掌握硬件性能调优 【免费下载链接】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. 项目地址: https://gitcod…...

Slide离线阅读功能详解:随时随地浏览Reddit内容的完整教程

Slide离线阅读功能详解:随时随地浏览Reddit内容的完整教程 【免费下载链接】Slide Slide is an open-source, ad-free Reddit browser for Android. 项目地址: https://gitcode.com/gh_mirrors/sl/Slide 你是否经常在地铁、飞机或网络信号不佳的地方想要浏览…...

Unity 2D基础:Rigidbody2D刚体的运动控制

Unity 2D基础:Rigidbody2D刚体的运动控制📚 本章学习目标:深入理解Rigidbody2D刚体的运动控制的核心概念与实践方法,掌握关键技术要点,了解实际应用场景与最佳实践。本文属于《Unity工程师成长之路教程》Unity 2D基础篇…...

Docker容器化高可用架构部署方案(十二)

11-MySQL-MGR初始化 本文档详细介绍MySQL MGR(Group Replication)集群的初始化步骤。 初始化前提 三个MySQL容器已正常运行 MySQL容器healthcheck通过 网络连通性正常 初始化步骤 步骤1:等待MySQL容器就绪 # 查看MySQL容器状态 docke…...

openLCA 2.6.2 完整安装与使用指南:免费开源的生命周期评估解决方案

openLCA 2.6.2 完整安装与使用指南:免费开源的生命周期评估解决方案 【免费下载链接】olca-app Source code of openLCA 项目地址: https://gitcode.com/gh_mirrors/ol/olca-app openLCA 是一款功能强大的开源生命周期评估软件,专门用于产品从原材…...

终极指南:Visual C++运行库合集AIO - 一站式解决Windows软件依赖问题

终极指南:Visual C运行库合集AIO - 一站式解决Windows软件依赖问题 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 还在为运行软件时遇到"找不到…...

Windows 11 LTSC微软商店安装终极指南:5分钟快速解决方案

Windows 11 LTSC微软商店安装终极指南:5分钟快速解决方案 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore Windows 11 LTSC版本以其卓越的稳…...