牛客热题:链表相加(二)

📟作者主页:慢热的陕西人

🌴专栏链接:力扣刷题日记

📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言

文章目录

牛客热题:链表相加(二)

题目链接

链表相加(二)_牛客题霸_牛客网 (nowcoder.com)

方法一:反转

思路

  • 将两个链表head1和head2都进行反转
  • 然后将两个链表相加的结果存储在另一个链表之中

代码

cpp 复制代码
    ListNode* ReverseList(ListNode* head)
    {
        //空链表直接返回和一个节点的情况
        if(head == nullptr || head->next == nullptr) return head;
         
        ListNode* cur = head;
 
        ListNode* n = cur->next;
 
        ListNode* pre = nullptr;
 
        while(cur != nullptr)
        {
            cur->next = pre;
            pre = cur;
            cur = n;
            if(n != nullptr)
            n = n->next;
        }
 
        return pre;
    }

    ListNode* addInList(ListNode* head1, ListNode* head2) 
    {
        ListNode* sum = new ListNode(0);

        ListNode* h1 = ReverseList(head1);
        ListNode* h2 = ReverseList(head2);
        ListNode* s = sum;
        int v = 0;
        while(h1 != nullptr || h2 != nullptr)
        {
            v /= 10;
            if(h1 != nullptr) v += h1->val, h1 = h1->next;
            if(h2 != nullptr) v += h2->val, h2 = h2->next;
            s->next = new ListNode(v % 10);
            s = s->next;
        }
        v /= 10;
        if(v)
        {
            s->next = new ListNode(v % 10);
            s = s->next;
        }

        sum->next = ReverseList(sum->next);

        return sum->next;
    }

复杂度

时间复杂度:O(N), 反转是O(N), 相当于遍历了两次链表

空间复杂度:O(M + N), 创建了一个max(m, n) + 1的链表

相关推荐
I_LPL5 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
m0_672703319 小时前
上机练习第51天
数据结构·c++·算法
仰泳的熊猫10 小时前
题目2577:蓝桥杯2020年第十一届省赛真题-走方格
数据结构·c++·算法·蓝桥杯
灰色小旋风10 小时前
力扣13 罗马数字转整数
数据结构·c++·算法·leetcode
ccLianLian12 小时前
数论·欧拉函数
数据结构·算法
会编程的土豆12 小时前
C++中的 lower_bound 和 upper_bound:一篇讲清楚
java·数据结构·算法
HUTAC13 小时前
关于进制转换及其应用的算法题总结
数据结构·c++·算法
小刘不想改BUG13 小时前
LeetCode 138.随机链表的复制 Java
java·leetcode·链表·hash table
XW010599913 小时前
6-函数-1 使用函数求特殊a串数列和
数据结构·python·算法
沉鱼.4413 小时前
枚举问题集
java·数据结构·算法