
LeetCode Add Two Numbers
初始状态:假设两个链表都有节点,我们从两者当前节点的值开始相加。 创建新的节点:将相加的结果存储到新的节点中。 处理进位:如果结果大于等于10,将进位值设为结果整除10的商,并将结果取余数存储到新的节点中。 移动指针:将当前链表的指针向前移动一位,同时注意处理可能提前结尾的情况。
初始化:检查两个链表的头节点,如果都为空则返回空链表。 循环加法:从两个链表的尾部节点开始逐位相加,直到至少有一个链表的节点耗尽。 创建新节点:将当前相加值存储到新的链表节点中,并更新进位值。 处理剩余节点:在当前链表有节点剩余时,继续加法并加上可能的进位。 处理最终进位:如果最后一次加法产生了进位,将其存储到新的节点中。
发布日期:2025-04-05 00:40:20
浏览次数:11
分类:精选文章
本文共 2539 字,大约阅读时间需要 8 分钟。
singly-linked-list: 模拟数字加法
在现实的编程练习中,我们有时会遇到需要通过模拟手动加法来完成算法实现的情况。这种方法通常用于处理类似数字相加的问题,尤其是在编写测试用例或练习数据操作时特别实用。以下,我将详细介绍如何使用singly-linked list(单向链表)的方式来模拟数字的加法,并处理可能的进位问题。
模拟数字加法的逻辑
输入
我们的输入是两个由数字节点组成的链表,每个节点包含一个数字值,还有一个指向下一个节点的指针。需要注意的是,这些节点的数字是按逆序存储的。例如,数字42被表示为2 -> 4
,也就是4节点指向2节点。
制作链表
比如,输入:
(2 -> 4 -> 3) + (5 -> 6 -> 4)
我们可以创建以下链表结构:
- 链表A:3 -> 2 -> 4
- 链表B:4 -> 6 -> 5
加法过程
我们可以从链表的第一个节点(末尾)开始加起来,每一步计算当前节点的值之和,再处理可能的进位。具体步骤如下:
完整的加法逻辑
class Solution {public: struct ListNode { int val; ListNode *next; ListNode(int x) : val(x), next(NULL) {} }; ListNode *addTwoNumbers(ListNode *l1, ListNode *l2) { if (l1 == NULL && l2 == NULL) return NULL; ListNode *head = NULL; ListNode *pre = NULL; int carry = 0; while (l1 && l2) { int sum = l1->val + l2->val + carry; carry = sum / 10; int val = sum % 10; ListNode *node = new ListNode(val); if (head == NULL) { head = node; } else { pre->next = node; } pre = node; l1 = l1->next; l2 = l2->next; } // 处理可能剩下的节点 while (l1) { int sum = l1->val + carry; carry = sum / 10; int val = sum % 10; ListNode *node = new ListNode(val); if (head == NULL) { head = node; } else { pre->next = node; } pre = node; l1 = l1->next; } while (l2) { int sum = l2->val + carry; carry = sum / 10; int val = sum % 10; ListNode *node = new ListNode(val); if (head == NULL) { head = node; } else { pre->next = node; } pre = node; l2 = l2->next; } // 处理最后的进位 if (carry > 0) { ListNode *node = new ListNode(carry); if (head == NULL) { head = node; } else { pre->next = node; } } return head; }}
总结
通过上述算法,我们完整地完成了两个单向链表的加法操作,包括处理进位等问题。这种方法能够确保我们能正确地将两个数字相加,并以链表的形式返回结果。
操作流程总结
这种方法确保了我们能够正确地将两个数字相加,并返回合并后的结果。
发表评论
最新留言
初次前来,多多关照!
[***.217.46.12]2025年04月20日 19时22分49秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
2024最新程序员接活儿搞钱平台盘点
2023-01-24
2024最火专业解读:信息安全(非常详细)零基础入门到精通,收藏这一篇就够了
2023-01-24
2025最新大模型技术学习过程梳理,零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新0基础怎么转行网络安全?零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新Bash Shell入门指南,零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新C++快速入门(适合小白)零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新关于HW护网行动的一些知识,零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新大模型学习路线,零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新大模型开发流程(非常详细)零基础入门到精通,收藏这一篇就够了
2023-01-25
2025版最新大模型微调方法(非常详细)零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新大语言模型的指令微调,零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新小白学习大模型:什么是大模型?零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新常用黑客工具之【Nmap 教程基础】零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新渗透测试和黑客工具列表,零基础入门到精通,收藏这一篇就够了
2023-01-25
2025版最新网络安全等级保护测评指南,零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新运维怎么转行网络安全?零基础入门到精通,收藏这篇就够了
2023-01-25
2025版最新黑客学习网站(非常详细),零基础入门到精通,看这一篇就够了
2023-01-25
2025版网络工程11个高含金量证书(非常详细)零基础入门到精通,收藏这篇就够了
2023-01-25
2025自学成为黑客必读的5本书籍,带你从小白进阶成大佬
2023-01-25