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

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

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

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

文章目录

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

题目链接

链表相加(二)_牛客题霸_牛客网 (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的链表

相关推荐
Bunury18 分钟前
组件封装-List
javascript·数据结构·list
Joeysoda21 分钟前
Java数据结构 (从0构建链表(LinkedList))
java·linux·开发语言·数据结构·windows·链表·1024程序员节
比特在路上25 分钟前
ListOJ14:环形链表II(寻找环的入口点)
数据结构·链表
涅槃寂雨4 小时前
C语言小任务——寻找水仙花数
c语言·数据结构·算法
『往事』&白驹过隙;4 小时前
操作系统(Linux Kernel 0.11&Linux Kernel 0.12)解读整理——内核初始化(main & init)之缓冲区的管理
linux·c语言·数据结构·物联网·操作系统
就爱学编程4 小时前
从C语言看数据结构和算法:复杂度决定性能
c语言·数据结构·算法
半桔4 小时前
栈和队列(C语言)
c语言·开发语言·数据结构·c++·git
墨楠。6 小时前
数据结构学习记录-树和二叉树
数据结构·学习·算法
Aqua Cheng.6 小时前
MarsCode青训营打卡Day10(2025年1月23日)|稀土掘金-147.寻找独一无二的糖葫芦串、119.游戏队友搜索
java·数据结构·算法
qy发大财6 小时前
平衡二叉树(力扣110)
数据结构·算法·leetcode·职场和发展