当前位置:首页 > 力扣 > 力扣第二题详解:模拟竖式加法,链表操作如此简单

力扣第二题详解:模拟竖式加法,链表操作如此简单

7个月前 (05-16)

题目要求将两个非负整数以链表形式相加,并以相同形式的链表返回结果。两个链表中的每个节点代表一个数字位,且链表中的数字是逆序存储的(例如,数字 123 对应的链表为 3 -> 2 -> 1)。我们需要计算它们的和,并以相同的逆序链表形式返回。问题的核心在于模拟竖式加法,正确处理进位,并处理两个链表长度不同的情况。

力扣第二题详解:模拟竖式加法,链表操作如此简单 力扣 链表 迭代 模拟 第1张

解题思路与过程

1‌.哑节点简化操作‌
使用一个哑节点(head)作为新链表的起点,避免处理头节点的边界条件。

‌2.遍历链表并逐位相加‌
同时遍历两个输入链表,若其中一条链表已经遍历结束,则用值为 0 的节点代替,确保位数对齐。

3‌.处理进位‌
每次计算当前位的和时,需加上前一位的进位值 a,并更新新的进位值。

4‌.动态扩展结果链表‌
每次迭代生成一个新节点保存当前位的计算结果,并将其链接到结果链表中。

‌5.终止条件‌
当两条链表均遍历结束且进位值为 0 时,终止循环。

代码:

class Solution {  
public:  
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {  
        ListNode* head = new ListNode;       // 创建哑节点作为结果链表的起点  
        ListNode* head1 = head;              // 保存哑节点指针,用于最终返回结果  
        int a = 0;                           // 进位值初始化为0  
        while (l1 || l2 || a != 0) {         // 当链表未遍历完或仍有进位时继续  
            if (!l1) {                       // 若 l1 已结束,补零以对齐位数  
                l1 = new ListNode(0);  
            }  
            if (!l2) {                       // 若 l2 已结束,补零以对齐位数  
                l2 = new ListNode(0);  
            }  
            ListNode* node = new ListNode;   // 创建新节点保存当前位的结果  
            head->next = node;               // 将新节点链接到结果链表  
            node->val = (l1->val + l2->val + a) % 10;  // 计算当前位的值  
            a = (l1->val + l2->val + a) / 10;          // 更新进位值  
            head = head->next;               // 移动结果链表指针  
            l1 = l1->next;                   // 移动 l1 指针  
            l2 = l2->next;                   // 移动 l2 指针  
        }  
        return head1->next;                  // 返回哑节点的下一个节点(即实际结果)  
    }  
};


原创内容 转载请注明出处

分享给朋友:

相关文章

线性遍历+二进制 6行代码征服二进制链表转整数

线性遍历+二进制 6行代码征服二进制链表转整数

力扣1290.二进制链表转整数题目本质给定一个单链表的头节点head,链表中每个节点的值为0或1。链表表示一个‌最高有效位在前‌的二进制数字,要求将其转换为对应的十进制整数。例如链表1→0→1对应的二...

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

题目解读给定一个整数数组,我们需要找到一个中心索引,使得该索引左侧所有元素的和等于右侧所有元素的和。如果不存在这样的索引,则返回-1。中心索引的定义不包含在左右两侧的和计算中。这个问题考察对数组遍历和...

力扣144:递归之美 轻松掌握二叉树前序遍历

力扣144:递归之美 轻松掌握二叉树前序遍历

题目解读二叉树的前序遍历是一种基础但重要的树遍历方式,其遍历顺序为:先访问根节点,然后递归地前序遍历左子树,最后递归地前序遍历右子树。给定一个二叉树的根节点,我们需要按照这个顺序访问所有节点,并将它们...

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

一、题目解读力扣3112题要求解决带时间限制的最短路径问题:给定一个有向图,节点具有消失时间,需计算从起点到各节点的最短路径,且路径总时间不能超过节点的消失时间。题目难点在于需在传统最短路径算法(如D...

【牛客157题】:反转链表指定区间(虚拟头节点解法)

【牛客157题】:反转链表指定区间(虚拟头节点解法)

一、题目解读牛客第157题要求反转链表中第m到n个节点(包含m和n)的区间,并保持其他节点顺序不变。例如,给定链表1→2→3→4→5,m=2,n=4,应返回1→4→3→2→5。题目重点在于处理边界条件...

LeetCode 2778题解:平方和的高效计算与因数遍历优化(C++实现)

LeetCode 2778题解:平方和的高效计算与因数遍历优化(C++实现)

一、题目解读LeetCode 2778题要求计算数组中下标为n的因数的元素的平方和。例如,若n=6,其因数为1、2、3、6,则需计算nums[0]、nums[1]、nums[2]、nums[5]的平方...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。