LeetCode2.两数相加

一、题目

二、思路

由于输入的两个链表都是逆序存储数字的每一位,所以两个链表中同一个位置的数字可以直接相加,同时遍历两个链表,逐位计算两个结点的数值之和,同时当前两个结点的数值之和还要加上来自低位的进位(因为逆序存储,所以低位就是两个链表的当前节点的前一个结点相加产生的进位),即设两个结点的当前节点分别为n1和n2,前一位的进位为carry,当前的和为n1+n2+carry,对应答案链表应该放的值为(n1+n2+carry)mod 10,新的进位值为(n1+n2+carry) / 10。

如果两个链表长度不同,可以认为长度短的链表后面有若干个0(短的说明高位为0,就是链表后面为0)。

当遍历结束后发现carry仍然大于0,说明最高位相加时产生了进位,将这个进位值直接加在答案链表后面即可。

三、代码实现

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
       ListNode *head = nullptr, *tail = nullptr;
       int carry = 0;
       while(l1 || l2) {
            //如果结点值为空 将n1或者n2设置为0 对sum无影响
            int n1 = l1 ? l1 -> val : 0;
            int n2 = l2 ? l2 -> val : 0;
            int sum = n1 + n2 + carry;
            if(!head) {
                //当头结点为空 说明当前这个数字是头结点的值 赋值 同时将tail初始化为头结点的值
                head = tail = new ListNode(sum % 10);
            } else {
                tail -> next = new ListNode(sum % 10);
                tail = tail -> next;
            }
            //计算进位
            carry = sum / 10;
            if(l1) {
                l1 = l1 -> next;
            }
            if(l2) {
                l2 = l2 -> next;
            }
       }
       if(carry > 0) {
            //如果最高位产生进位 将进位放在答案链表末尾 表示答案的最高位的数值
            tail -> next = new ListNode(carry);
       }
       return head;
    }
};
相关推荐
大胆飞猪3 小时前
递归、剪枝、回溯算法---全排列、子集问题(力扣.46,78)
算法·leetcode·剪枝
Kisorge5 小时前
【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
stm32·嵌入式硬件·算法
铭哥的编程日记6 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(二)基础算法(下)
算法·职场和发展·蓝桥杯
Swift社区7 小时前
LeetCode 421 - 数组中两个数的最大异或值
算法·leetcode·职场和发展
cici158747 小时前
基于高光谱成像和偏最小二乘法(PLS)的苹果糖度检测MATLAB实现
算法·matlab·最小二乘法
StarPrayers.8 小时前
自蒸馏学习方法
人工智能·算法·学习方法
大锦终8 小时前
【动规】背包问题
c++·算法·动态规划
智者知已应修善业9 小时前
【c语言蓝桥杯计算卡片题】2023-2-12
c语言·c++·经验分享·笔记·算法·蓝桥杯
hansang_IR9 小时前
【题解】洛谷 P2330 [SCOI2005] 繁忙的都市 [生成树]
c++·算法·最小生成树
Croa-vo9 小时前
PayPal OA 全流程复盘|题型体验 + 成绩反馈 + 通关经验
数据结构·经验分享·算法·面试·职场和发展