Every day a leetcode
题目来源:2. 两数相加
解法:模拟
设置两个指针,p指向l1的头,q指向l2的头,m为p的值,n为q的值。
显然,空结点的值为0。
sum=m+n(+carry),若sum大于10,则向后进一位,否则不用。
设置一个carry,carry=sum/10,即sum的高位,sum%10是sum的低位。
新建一个链表,初始话化为空,每次得一个sum就将sum%10尾插进这个链表,若最后的carry为1,还需要插入这个1。
代码:
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2){
struct ListNode* head=NULL;
struct ListNode* tail=NULL;
struct ListNode* p=l1;
struct ListNode* q=l2;
struct ListNode* node;
int sum;
int carry=0;
int m,n;
while(p || q || carry)
{
if(p) m=p->val;
else m=0;
if(q) n=q->val;
else n=0;
sum=m+n+carry;
carry=sum/10;
node=malloc(sizeof(struct ListNode));
if(head == NULL)
{
head=tail=node;
tail->val=sum%10;
tail->next=NULL;
}
else
{
tail->next=node;
tail=tail->next;
tail->val=sum%10;
tail->next=NULL;
}
if(p) p=p->next;
if(q) q=q->next;
}
return head;
}
结果:

三分钟就想到了,但写了好久。。。
这篇博客详细介绍了如何使用模拟法解决链表问题,具体为两数相加。通过设置两个指针遍历两个链表,逐位相加并处理进位,最终构建新的链表表示结果。博主在三分钟内构思出解题思路,但编写代码花费了一些时间。
1377

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



