LeetCode 两数相加

思路:这道题需要注意的的点就是进位,两个数相加后如果产生进位,就要在下一位相加时添加上1,这里用addition这个变量储存,如果产生进位,addition=1,加在下一个数上

另外就是补位问题,如果两个数位数不同,对较短的链表补位,方便下面相加。

cpp 复制代码
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) {
		int length1=1, length2=1;
		ListNode* q1=l1;//统计l1的长度
		ListNode* q2 = l2;//统计l2的长度
		while (q1->next != nullptr)
		{
			length1++;
			q1 = q1->next;
		}
		while (q2->next != nullptr)
		{
			length2++;
			q2 = q2->next;
		}
		if (length1 > length2)//给没有对齐的位补零
		{
			for (int i = length2; i <= length1; i++)
			{
				q2->next = new ListNode(0);
				q2 = q2->next;//每增加一个节点都要往后移动一位
			}
		}
		else {
			if (length1 < length2)
			{
				for (int i = length1; i < length2; i++)
				{
					q1->next = new ListNode(0);
					q1 = q1->next;
				}
			}
		}
		q1 = l1;
		q2 = l2;
		//创建一个新的链表,用来储存答案
		bool addition = false;
		ListNode* l3 = new ListNode(-1);
		ListNode* cur = l3;
		while (q1 && q2)
		{
			int temp = addition + q1->val + q2->val;
			cur->next = new ListNode(temp % 10);//将个位的数字放入节点
			addition = temp / 10;
			//将每个节点往后移
			q1 = q1->next;
			q2 = q2->next;
			cur = cur->next;
		}
		if (addition)//最后一位相加时产生的进位
		{
			cur->next = new ListNode(1);
			cur = cur->next;//节点后移

		}
		return l3->next;//取头节点往下的节点
	}
};
相关推荐
Swift社区3 小时前
LeetCode 394. 字符串解码(Decode String)
算法·leetcode·职场和发展
tt5555555555554 小时前
LeetCode进阶算法题解详解
算法·leetcode·职场和发展
让我们一起加油好吗4 小时前
【基础算法】DFS中的剪枝与优化
算法·深度优先·剪枝
Q741_1474 小时前
C++ 模拟题 力扣495. 提莫攻击 题解 每日一题
c++·算法·leetcode·模拟
Felven5 小时前
A. Be Positive
算法
小O的算法实验室5 小时前
2026年COR SCI2区,自适应K-means和强化学习RL算法+有效疫苗分配问题,深度解析+性能实测,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
青岛少儿编程-王老师6 小时前
CCF编程能力等级认证GESP—C++7级—20250927
数据结构·c++·算法
夏鹏今天学习了吗6 小时前
【LeetCode热题100(39/100)】对称二叉树
算法·leetcode·职场和发展
天选之女wow7 小时前
【代码随想录算法训练营——Day34】动态规划——416.分割等和子集
算法·leetcode·动态规划
Boop_wu7 小时前
[数据结构] 哈希表
算法·哈希算法·散列表