当前位置:首页 > 力扣 > 力扣第2题:三步掌握递归解法与进位传递技巧

力扣第2题:三步掌握递归解法与进位传递技巧

4个月前 (05-10)

给定两个非空链表,每个链表代表一个非负整数。数字按照逆序存储(如整数 342 存储为 2→4→3),要求将这两个数相加并以相同形式的链表返回结果。例如输入 2→4→3 和 5→6→4,它们的和是 807,输出应为 7→0→8。问题本质是实现按位相加,并处理进位和链表长度不一致的情况。


递归解法思路与过程‌:

1‌.递归终止条件‌:当两个链表均为空且无进位时结束递归。

‌2.补齐短链表‌:若其中一个链表已走到末尾,则创建一个值为 0 的节点,保证后续递归中位数对齐。

‌3.计算当前值和进位‌:将当前位的值相加并加上进位,取模得到当前节点值,整除得到新的进位。

4‌.递归连接节点‌:新建节点保存当前位的值,并将其作为当前节点的后继,继续递归处理下一位。


力扣第2题:三步掌握递归解法与进位传递技巧 力扣 递归 链表 单链表 第1张


代码:

class Solution {
public:
    void add(ListNode* l1, ListNode* l2, int a, ListNode* head) {
        // 终止条件:两链表为空且进位为0
        if (l1 || l2 || a != 0) {
            // 若当前链表指针为空,创建值为0的节点补齐
            if (!l1) {
                ListNode* tmp = new ListNode(0);
                l1 = tmp;
            }
            if (!l2) {
                ListNode* tmp = new ListNode(0);
                l2 = tmp;
            }
            // 新建节点存储当前位的计算结果
            ListNode* tmp = new ListNode;
            int b = l1->val + l2->val + a;  // 当前位的和(包括进位)
            tmp->val = b % 10;               // 当前位的值
            a = b / 10;                      // 新的进位
            head->next = tmp;                // 将当前节点连接到结果链表
            // 递归处理下一位,传入下一节点和进位
            add(l1->next, l2->next, a, tmp);
        }
    }

    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode* head = new ListNode;      // 创建哑节点作为结果链表的头部
        add(l1, l2, 0, head);               // 从初始进位0开始递归
        return head->next;                  // 返回哑节点的后继,即真正的结果链表
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣198.打家劫舍|动态规划解法中的特殊边界处理

力扣198.打家劫舍|动态规划解法中的特殊边界处理

题意解析:在排列成直线的房屋群中,每个房屋藏有价值不同的财物。小偷不能连续抢劫相邻的两间房屋,否则会触发警报。我们需要设计一套抢劫策略,使得在不触发警报的前提下,能够获取的最大财物总和。这个问题本质上...

力扣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。题目重点在于处理边界条件...

【牛客227题解析】合并K个有序链表的优先队列解法(附代码)

【牛客227题解析】合并K个有序链表的优先队列解法(附代码)

一、题目解读牛客227题要求合并K个有序链表,即将多个有序的单向链表合并成一个有序链表。题目考察的核心是对链表操作的熟练度以及高效算法的设计,通常需要平衡时间复杂度和空间复杂度,确保合并过程稳定且高效...

LeetCode 2074题解:反转链表中的节点间隔(虚拟节点+分组反转)

LeetCode 2074题解:反转链表中的节点间隔(虚拟节点+分组反转)

一、题目解读LeetCode 2074题要求对链表进行分组反转:将链表按节点数分组,若当前组长度为偶数则反转该组节点,奇数长度则保持不变。例如,输入链表 [1,2,3,4,5,6],分组后 [1,2,...

牛客4499题解:二叉树中序遍历

牛客4499题解:二叉树中序遍历

一、题目解读牛客4499题要求模拟折纸过程并输出折痕方向。题目给定整数n表示折纸次数,需要生成一个包含"down"(下折)和"up"(上折)的序列,反映每次折纸...

发表评论

访客

看不清,换一张

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