0
点赞
收藏
分享

微信扫一扫

夯实C++基础之刷题:链表——7 链表求和 两数相加

ZSACH 2022-04-24 阅读 66

在这里插入图片描述

解题内容

看了题解 脑子里就都是题解……脑子不清楚的时候 很不想链表上画来画去。嗷嗷嗷什么时候可以下了班还精力充沛!
下次我再来写链表反转直接相加

class Solution {
public:
    ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
        stack<int> s1, s2;
        while (l1) {
            s1.push(l1 -> val);
            l1 = l1 -> next;
        }
        while (l2) {
            s2.push(l2 -> val);
            l2 = l2 -> next;
        }
        int carry = 0;
        ListNode* ans = nullptr;
        while (!s1.empty() or !s2.empty() or carry != 0) {
            int a = s1.empty() ? 0 : s1.top();
            int b = s2.empty() ? 0 : s2.top();
            if (!s1.empty()) s1.pop();
            if (!s2.empty()) s2.pop();
            int cur = a + b + carry;
            carry = cur / 10;
            cur %= 10;
            auto curnode = new ListNode(cur);
            curnode -> next = ans;
            ans = curnode;
        }
        return ans;
    }
};
举报

相关推荐

0 条评论