2.两数相加:
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 0 之外,这两个数都不会以 0 开头。
示例 1:

输入:l1 = [2,4,3], l2 = [5,6,4]
输出:[7,0,8]
解释:342 + 465 = 807.
示例 2:
输入:l1 = [0], l2 = [0]
输出:[0]
示例 3:
输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
输出:[8,9,9,9,0,0,0,1]
提示:
每个链表中的节点数在范围 [1, 100] 内
0 <= Node.val <= 9
题目数据保证列表表示的数字不含前导零
分析:
虽然在第二题,但感觉并不简单。
同时遍历两个链表,先遍历完的补0,设置两个存放数字的变量n1,n2分别放相应两个链表的对应值。再设置一个carry表示进位(注意最后一位如果进位要再加一个结点存放。剩下就是mod-%和carry的求法/。还有一个注意点是要先分配下一个结点再放数,还是先放数再分配下一个结点。答案是先分配下一个结点,因为遍历到最后一个结点时,如果先放数再分配一个结点,这样会多出一个没有数值的结点(血泪史:最后一位一直输出-109一堆),说白了就是带头结点的单链表,哑结点也可以尝试用。
代码:
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2){
struct ListNode *head=(struct ListNode*)malloc(sizeof(struct ListNode));
head->next=NULL;
struct ListNode *tail=head;
int carry=0,n1,n2,sum=0; //carry标记进位
while(l1||l2){
if(l1)
n1=l1->val;
else
n1=0;
if(l2)
n2=l2->val;
else
n2=0;
sum=n1+n2+carry;
tail->next=(struct ListNode*)malloc(sizeof(struct ListNode)); //注意顺序
tail->next->val=sum%10; //再赋值
tail=tail->next;
tail->next=NULL;
carry=sum/10;
if(l1)
l1=l1->next;
if(l2)
l2=l2->next;
}
if(carry>0){
tail->next=(struct ListNode*)malloc(sizeof(struct ListNode));
tail=tail->next;
tail->val=carry;
tail->next=NULL;
}
return head->next; //第一个结点是没有放数的
}
该博客详细介绍了如何实现两个用链表表示的非负整数相加,每个节点存储一位数字,逆序排列。通过遍历两个链表,逐位相加并处理进位,最后返回表示和的链表。代码中特别强调了处理最后一个节点进位的情况,以及分配新节点的顺序对结果的影响。
532

被折叠的 条评论
为什么被折叠?



