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

【Hot 100 刷题计划】 LeetCode 2. 两数相加 | C++ 分支迭代法

LeetCode 2. 两数相加 题目描述题目级别中等给你两个非空的链表表示两个非负的整数。它们每位数字都是按照逆序的方式存储的并且每个节点只能存储一位数字。请你将两个数相加并以相同形式返回一个表示和的链表。你可以假设除了数字 0 之外这两个数都不会以 0 开头。示例 1:输入l1 [2,4,3], l2 [5,6,4]输出[7,0,8]解释342 465 807。 破题思路按位模拟与严谨的分支处理因为链表已经是逆序排列的个位在头高位在尾这刚好符合我们做“竖式加法”从低位向高位进位的习惯。我们可以维护一个进位/求和变量sum并在循环中严格区分三种物理情况l1和l2都没走完此时将两者的当前节点值相加并加上上一轮留下的进位sum。算出当前位sum % 10并接入结果链表同时更新进位sum / 10。只有l1没走完此时l2已经到头了只需要拿l1的值去和上一轮的进位sum相加计算当前位和新的进位。只有l2没走完同理只处理l2和进位sum的相加。极客细节虚拟头节点的内存管理在处理这种需要创建新链表的题目时很多时候我们会用ListNode* dummy new ListNode(0);来做虚拟头节点。但这在 C 中如果没有对应的delete是会导致内存泄漏的。这里的解法极其巧妙地使用了栈上分配ListNode res(0);然后再用指针ListNode* cur res;去进行后续的拼接。函数结束时res会被系统自动回收不仅运行速度更快而且做到了绝对的内存安全 C 代码实现classSolution{public:ListNode*addTwoNumbers(ListNode*l1,ListNode*l2){// 在栈上分配虚拟头节点安全高效杜绝内存泄漏ListNoderes(0);ListNode*curres;// sum 既用来记录当前的累加和也用来向下一位传递进位intsum0;while(l1||l2){// 情况 1两个链表都还有数字if(l1l2){suml1-vall2-val;cur-nextnewListNode(sum%10);// 取个位数接入新链表curcur-next;sum/10;// 取十位数作为进位保留到下一轮l1l1-next,l2l2-next;}// 情况 2l2 已经走完了只剩 l1elseif(l1){suml1-val;cur-nextnewListNode(sum%10);curcur-next;sum/10;l1l1-next;}// 情况 3l1 已经走完了只剩 l2elseif(l2){suml2-val;cur-nextnewListNode(sum%10);curcur-next;sum/10;l2l2-next;}}// 终极扫尾如果两个链表都走完了但最后还有进位没处理比如 9 9 18 的那个 1if(sum)cur-nextnewListNode(sum%10);// 返回虚拟头节点的下一个节点即真实的合并结果returnres.next;}};

相关文章:

【Hot 100 刷题计划】 LeetCode 2. 两数相加 | C++ 分支迭代法

LeetCode 2. 两数相加 📌 题目描述 题目级别:中等 给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示…...

Go JSON 序列化与反序列化性能对比

Go JSON序列化与反序列化性能对比 在现代Web开发和微服务架构中,JSON作为轻量级的数据交换格式被广泛应用。Go语言以其高效的并发性能和简洁的语法,成为许多开发者的首选。在处理JSON数据时,序列化与反序列化的性能直接影响系统的响应速度和…...

扩散大语言模型在CUDA代码生成中的创新应用

1. 扩散大语言模型在代码生成领域的突破作为一名长期从事高性能计算和AI模型优化的工程师,我见证了从传统编程到AI辅助代码生成的范式转变。扩散大语言模型(dLLMs)的出现,为代码生成领域带来了全新的可能性。与常见的自回归模型&a…...

Element Plus的el-upload组件,如何优雅集成阿里云OSS分片上传与进度条?

Element Plus与阿里云OSS分片上传深度实践:打造高可靠大文件上传方案 在当今数字化办公场景中,视频素材、设计原稿等大文件上传已成为内容管理系统的标配需求。传统单次上传在面对数百MB甚至GB级文件时,往往面临网络波动中断、进度反馈缺失、…...

Evernote-backup 终极指南:从数据锁仓到自由迁移的完整解决方案

Evernote-backup 终极指南:从数据锁仓到自由迁移的完整解决方案 【免费下载链接】evernote-backup Backup & export all Evernote notes and notebooks 项目地址: https://gitcode.com/gh_mirrors/ev/evernote-backup 想象一下:你的数字记忆被…...

AISHELL-Gate语音识别服务:从模型部署到工程化实践

1. 项目概述与核心价值最近在折腾语音交互项目,发现一个挺有意思的仓库:aishell-gate/aishell-gate。乍一看名字,你可能会联想到著名的中文语音数据集AISHELL,没错,这个项目正是围绕它构建的一个“网关”或“接口”服务…...

Power BI Desktop新手避坑指南:从安装到第一个仪表盘,我踩过的雷都帮你填平了

Power BI Desktop新手避坑指南:从安装到第一个仪表盘,我踩过的雷都帮你填平了 第一次打开Power BI Desktop时,那种既兴奋又茫然的感觉我至今记得——界面上密密麻麻的按钮,陌生的术语,还有随时可能跳出来的报错提示。作…...

ILSpy终极指南:免费开源的.NET程序集浏览器和反编译器

ILSpy终极指南:免费开源的.NET程序集浏览器和反编译器 【免费下载链接】ILSpy .NET Decompiler with support for PDB generation, ReadyToRun, Metadata (&more) - cross-platform! 项目地址: https://gitcode.com/gh_mirrors/il/ILSpy 你是否曾经面对一…...

解锁Android Auto隐藏功能:无需Root安装第三方应用全指南

解锁Android Auto隐藏功能:无需Root安装第三方应用全指南 【免费下载链接】AAAD The original application for downloading and installing apps made specifically for Android Auto outside of Google Play Store. Active since 2021. 项目地址: https://gitco…...

STM32+OLED+DHT11:做一个能显示温湿度的迷你气象站(开源硬件清单)

STM32OLEDDHT11:打造高性价比桌面气象站的完整指南 从零开始构建你的迷你气象站 去年夏天,我在工作室调试设备时,发现窗台上的植物总是蔫蔫的。直到偶然用温湿度计测量才发现,这个角落的湿度比房间其他位置低了近30%。这个发现让我…...

终极指南:9种字重的开源几何无衬线字体Outfit完全解析

终极指南:9种字重的开源几何无衬线字体Outfit完全解析 【免费下载链接】Outfit-Fonts The most on-brand typeface 项目地址: https://gitcode.com/gh_mirrors/ou/Outfit-Fonts Outfit字体是一款专业的开源几何无衬线字体,专为品牌自动化设计而生…...

DragFlow框架:基于区域仿射监督的DiT图像编辑突破

1. 项目概述:DragFlow框架的核心突破在生成式AI快速发展的当下,图像编辑技术正经历从全局调整到像素级精确控制的范式转变。传统基于Stable Diffusion(SD)的拖拽编辑方法虽然实现了基本的交互式操作,但在处理复杂结构图…...

终极电池保护指南:BatteryChargeLimit如何让你的手机电池寿命延长一倍

终极电池保护指南:BatteryChargeLimit如何让你的手机电池寿命延长一倍 【免费下载链接】BatteryChargeLimit 项目地址: https://gitcode.com/gh_mirrors/ba/BatteryChargeLimit 你是否曾经为手机电池的快速衰减而烦恼?是否发现新手机使用一年后&…...

Allegro 16.6出Gerber避坑指南:从钻孔表到槽孔,新手必看的5个细节

Allegro 16.6出Gerber避坑指南:从钻孔表到槽孔,新手必看的5个细节 第一次使用Allegro 16.6输出Gerber文件时,那种既兴奋又忐忑的心情我至今记忆犹新。作为PCB设计流程中的关键环节,Gerber文件的质量直接决定了最终电路板的成败。本…...

从原理图到仿真波形:一步步拆解FPGA矩阵键盘的“行扫描法”

从原理图到仿真波形:FPGA矩阵键盘行扫描法的深度解析 在嵌入式系统开发中,矩阵键盘是一种常见且经济高效的人机交互解决方案。本文将带领读者从硬件原理到Verilog实现,逐步拆解FPGA驱动4x4矩阵键盘的全过程,特别聚焦行扫描法的实现…...

Air724UG模块(4G全网通GPRS开发)-下载AT或者DTU固件和入门使用

Air724UG(4G全网通GPRS)开发-硬件使用说明模块简介1.实物图2.尺寸引脚图3.模块供电①:micro,usb接口供电②:VCC供电(5V~18V)③:VBAT供电(3.6V~4.3V)4.AT指令通信使用MCU和模块进行AT指令通信时,需要用到以下引脚;RX1:模组串口AT指令接收数据引脚;TX1:模组串口AT指令发送数据引脚…...

5个高效配置技巧:Tvheadend电视服务器深度解析

5个高效配置技巧:Tvheadend电视服务器深度解析 【免费下载链接】tvheadend Tvheadend is the leading TV streaming server for Linux with ATSC, DVB-C/C2, DVB-S/S2, DVB-T/T2, IPTV, SAT>IP and unix pipe input sources 项目地址: https://gitcode.com/gh_…...

掌握 FloPy:Python 地下水流建模的完整指南

掌握 FloPy:Python 地下水流建模的完整指南 【免费下载链接】flopy A Python package to create, run, and post-process MODFLOW-based models. 项目地址: https://gitcode.com/gh_mirrors/fl/flopy FloPy 是一个功能强大的 Python 包,专门用于创…...

LLM策略合成在多智能体协作中的应用与优化

1. LLM策略合成:多智能体协作的新范式在传统多智能体强化学习(MARL)面临样本效率瓶颈的当下,大型语言模型(LLM)直接生成可执行策略代码的能力正在打开新的可能性。想象这样一个场景:10个智能体在虚拟环境中需要协调资源收集与公共物品维护&am…...

GodotPckTool完全解析:独立工具如何高效管理Godot游戏资源包

GodotPckTool完全解析:独立工具如何高效管理Godot游戏资源包 【免费下载链接】GodotPckTool Standalone tool for extracting and creating Godot .pck files 项目地址: https://gitcode.com/gh_mirrors/go/GodotPckTool 在Godot游戏开发流程中,资…...

别再死记公式了!用Proteus仿真带你直观理解运放的‘虚短’和‘虚断’

用Proteus仿真破解运放"虚短虚断":动态实验手册 第一次接触运算放大器时,教授在黑板上写下"虚短"和"虚断"四个字,台下二十多双眼睛里的困惑至今难忘。直到某天深夜,当我在Proteus里把示波器探头搭在…...

Display Driver Uninstaller深度解析:如何让显卡驱动问题迎刃而解

Display Driver Uninstaller深度解析:如何让显卡驱动问题迎刃而解 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-u…...

探索异端代码仓库:从设计哲学到工程实践的深度解析

1. 项目概述:一个“异端”的代码仓库在GitHub上,p-e-w/heretic这个项目名本身就充满了故事感。heretic,意为“异端”,在软件开发领域,这通常指向那些挑战主流范式、探索非传统路径的代码库。它不是某个知名框架的官方插…...

如何5秒内智能获取百度网盘提取码:免费开源工具实用指南

如何5秒内智能获取百度网盘提取码:免费开源工具实用指南 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 还在为百度网盘提取码而烦恼吗?每次找到心仪的学习资料、软件资源或影视内容,却卡在…...

为什么这个免费工具能让你3分钟搞定弹幕格式转换?

为什么这个免费工具能让你3分钟搞定弹幕格式转换? 【免费下载链接】DanmakuFactory 支持特殊弹幕的xml转ass格式转换工具 项目地址: https://gitcode.com/gh_mirrors/da/DanmakuFactory 还在为B站弹幕无法在其他播放器上显示而头疼吗?弹幕格式转换…...

别只盯着AlphaFold了!这5个免费蛋白质结构预测服务器,哪个更适合你的课题?

别只盯着AlphaFold了!这5个免费蛋白质结构预测服务器,哪个更适合你的课题? 刚拿到一条蛋白序列时,许多研究者会下意识地打开AlphaFold的界面。但你可能不知道的是,根据序列长度、同源模板可用性、计算资源等不同条件&…...

E7Helper:为《第七史诗》玩家设计的智能自动化助手

E7Helper:为《第七史诗》玩家设计的智能自动化助手 【免费下载链接】e7Helper 【Epic Seven Auto Bot】第七史诗多功能覆盖脚本(刷书签🍃,挂讨伐、后记、祭坛✌️,挂JJC等📛,多服务器支持📺&…...

别再只用SD卡了!手把手教你给W25Q16 SPI Flash移植FATFS文件系统(STM32实战)

嵌入式存储方案深度解析:为何W25Q16 SPI Flash比SD卡更适合你的项目? 在嵌入式系统开发中,存储方案的选择往往决定了项目的成败。许多开发者习惯性地选择SD卡作为默认方案,却忽视了更优的替代品——SPI Flash存储器。以W25Q16为代…...

Copilot Next 自动化工作流配置终极复盘(附可运行Demo仓库):涵盖Azure DevOps/Bitbucket/GitLab三平台适配,仅剩最后87份源码包

更多请点击: https://intelliparadigm.com 第一章:VS Code Copilot Next 自动化工作流配置 面试题汇总 VS Code Copilot Next 作为 GitHub 官方深度集成的下一代智能编程助手,其自动化工作流配置能力已成为前端与全栈工程师面试中的高频考点…...

K-Means聚类效果总不好?试试在Scikit-learn里用标准化欧氏距离优化你的模型

K-Means聚类效果总不好?试试在Scikit-learn里用标准化欧氏距离优化你的模型 当你在电商用户分群项目中遇到这样的场景:消费金额(0-10000元)和登录次数(1-100次)两个特征被放在同一个聚类模型里,…...