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

devtools/2024/9/24 9:20:12/

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

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

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

在这里插入图片描述

文章目录

  • 牛客热题:链表相加(二)
    • 题目链接
    • 方法一:反转
      • 思路
      • 代码
      • 复杂度

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

题目链接

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

方法一:反转

思路

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

代码

    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的链表


http://www.ppmy.cn/devtools/40749.html

相关文章

1900年-2100年公历转农历数据

数据 农历数据 0x04bd8, 0x04ae0, 0x0a570, 0x054d5, 0x0d260, 0x0d950, 0x16554, 0x056a0, 0x09ad0, 0x055d2, //1900-1909 0x04ae0, 0x0a5b6, 0x0a4d0, 0x0d250, 0x1d255, 0x0b540, 0x0d6a0, 0x0ada2, 0x095b0, 0x14977, //1910-1919 0x04970, 0x0a4b0, 0x0b4b5, 0x06a50, …

CSS拟物按钮

<div class"btn">F</div>.btn {margin: 150px 0 0 150px;display: flex;justify-content: center;align-items: center;width: 100px;height: 100px;background-color: #fff;border-radius: 20px;font-size: 50px;color: #333;/* 禁止选中文本 */user-se…

SQLI-labs-第十五关和第十六关

目录 知识点&#xff1a; 第十五关 1、判断注入点 2、判断当前数据库 3、判断表名 4、判断字段名 5、爆值 第十六关 1、判断注入点 知识点&#xff1a; POST方式的时间盲注 对应的函数利用&#xff0c;可参考SQLI-labs-第九关和第十关_sqllab第十关-CSDN博客 第十五…

【C++】STL-list的使用

目录 1、list的使用 1.1 list的构造 1.2 list的遍历 1.3 list capacity 1.4 list element access 1.5 容量相关 list是一个带头双向循环链表 1、list的使用 1.1 list的构造 1.2 list的遍历 list只有两种遍历方式&#xff0c;因为没有operator[] 因为list的双向链表&am…

智能呼叫中心客服系统:企业客户服务的新引擎

在如今商业竞争激烈的大环境下&#xff0c;企业的客户服务需求已不仅仅局限于简单的沟通。随着科技的进步&#xff0c;客户对于高效、智能的交互体验有着更高的期待。为了满足这些需求&#xff0c;智能呼叫中心客服系统应运而生&#xff0c;成为企业提升客户服务质量、优化客户…

npm 非常见命令

npm 非常见命令 部分与包名相关的命令以 axios 作为示例 npm view&#xff1a;查看包的元数据。 示例&#xff1a;npm view axios 将显示axios包的元数据&#xff0c;包括版本、作者、依赖等信息。 npm search&#xff1a;搜索npm仓库中与关键词相关的包。 示例&#xff1a;n…

开源数据可视化大屏对接表单数据实践!

如果你需要一个表单系统&#xff0c;进行数据收集&#xff1b;可以使用tduck填鸭进行私有化部署&#xff0c;进行表单制作&#xff0c;完成数据收集。 在实际业务中&#xff0c;往往需要将收集的数据进行展示或分析&#xff1b;此时就可以使用表单数据推送到TReport中&#xf…

插入排序(Insertion Sort)

插入排序&#xff08;Insertion Sort&#xff09;是一种简单直观的排序算法&#xff0c;它的工作原理如下&#xff1a; 将数组分为已排序部分和未排序部分&#xff1a;初始时&#xff0c;已排序部分仅包含数组的第一个元素&#xff0c;其余元素被视为未排序部分。 从未排序部分…