前言: 数字可以在整形里面存,也可以在以字符串的形式存,也可以以链表的方式存,下面就看看链表存的两个数相加。 【LeetCode】链接:2. 两数相加 - 力扣(LeetCode) 喜欢的铁子可以点点关注,祝大家天天开心!
问题描述: 给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 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
我们只要把每一个对应位上的val相加就可以,然后把超过10的进位。如果有一条链表到达空了,那么我们就把他看成0,用另外一条链表的val值继续进行计算,最后到达两个链表都到达尾部。如果最后我们看最后还有没有进位,如果还超过10,我们就再申请一个节点,把1放进去。每次我们走一步,就申请一个节点,记录新的节点的头和尾,每次增加一个节点,tail尾节点就往后面跟着移动,最后返回head。
另外,我们还可以先申请一个黑头,这样我们就不要去对新的头节点为NULL情况的考虑,最后也只要返回head->next.
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
typedef struct ListNode ListNode;
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2) {
ListNode* head,*tail;
head=tail=(ListNode*)malloc(sizeof(ListNode));
int carry=0;
while(l1||l2)
{
int n1=l1?l1->val:0;
int n2=l2?l2->val:0;
int sum=n1+n2+carry;
carry=sum/10;
tail->next=(ListNode*)malloc(sizeof(ListNode));
tail=tail->next;
tail->next=NULL;
tail->val=sum%10;
if(l1)
l1=l1->next;
if(l2)
l2=l2->next;
}
if(carry)
{
tail->next=(ListNode*)malloc(sizeof(ListNode));
tail=tail->next;
tail->val=1;
tail->next=NULL;
}
return head->next;
}
总结: 这种类型的题目还有很多,我们多去思考多去练习,把这类型的题目摸索情况。