题解 | #链表相加(二)#

链表相加(二)

https://www.nowcoder.com/practice/c56f6c70fb3f4849bc56e33ff2a50b6b

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */

class Solution {
public:
    /**
     * 
     * @param head1 ListNode类 
     * @param head2 ListNode类 
     * @return ListNode类
     */
    ListNode *reverseList(ListNode *head) {
        if (!head || !head->next) {
            return head;
        }
        ListNode *nxt = head->next;
        ListNode *res = reverseList(nxt);
        nxt->next = head;
        head->next = nullptr;
        return res;
    }

    ListNode* addInList(ListNode* head1, ListNode* head2) {
        if (!head1) return head2;
        if (!head2) return head1;
        head1 = reverseList(head1);
        head2 = reverseList(head2);
        ListNode *dummyhead = new ListNode(0), *tail = dummyhead;
        int up = 0;
        while (head1 && head2) {
            head1->val += head2->val + up;
            up = head1->val / 10;
            head1->val %= 10;
            tail->next = head1;
            tail = head1;
            head1 = head1->next;
            head2 = head2->next;
        }
        if (!head1) head1 = head2;
        while (head1) {
            head1->val += up;
            up = head1->val / 10;
            head1->val %= 10;
            tail->next = head1;
            tail = head1;
            head1 = head1->next;
        }
        if (up) {
            tail->next = new ListNode(1);
        }
        ListNode *res = dummyhead->next;
        dummyhead->next = nullptr;
        return reverseList(res);
    }
};

思路:同样是先反转链表,然后模拟加法,最后再反转回去。

因为链表与数组不同,最后注意如果有进位的话,是需要新建一个链表节点的。

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-11 11:29
点赞 评论 收藏
分享
06-15 02:05
已编辑
南昌航空大学 数据分析师
Eason三木:你如果想干技术岗,那几个发公众号合唱比赛的经历就去掉,优秀团员去掉,求职没用。然后CET4这种不是奖项,是技能,放到下面的专业技能里或者单独列一个英语能力。 另外好好改改你的排版,首行缩进完全没有必要,行间距好好调调,别让字和标题背景黏在一起,你下面说能做高质量PPT你得展现出来啊,你这简历排版我用PPT做的都能比你做的好。 然后自我评价,你如果要干数据工程师,抗压能力强最起码得有吧。
简历中的项目经历要怎么写
点赞 评论 收藏
分享
07-10 13:59
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务