【算法训练-链表 五】【求和】:链表相加(逆序)、链表相加II(顺序)

废话不多说,喊一句号子鼓励自己:程序员永不失业,程序员走向架构!本篇Blog的主题是【链表相加】,使用【链表】这个基本的数据结构来实现,这个高频题的站点是:CodeTop,筛选条件为:目标公司+最近一年+出现频率排序,由高到低的去牛客TOP101去找,只有两个地方都出现过才做这道题(CodeTop本身汇聚了LeetCode的来源),确保刷的题都是高频要面试考的题。

在这里插入图片描述

名曲目标题后,附上题目链接,后期可以依据解题思路反复快速练习,题目按照题干的基本数据结构分类,且每个分类的第一篇必定是对基础数据结构的介绍

链表相加【MID】

题干

首先来一道逆序版,稍微比较好搞一些的,因为链表只能向后遍历:
直接粘题干和用例

解题思路

整体思路就是遍历完两个链表进行相加并将结果集放到新的链表上

  1. 设置返回链表的链表头,设置进位cnt=0.
  2. 从头开始遍历两个链表,直到两个链表节点都为空:
    1. 每次取出不为空的链表节点值,为空就设置为0
    2. 将两个数字与cnt相加,就是当前的总和
    3. 将总和(对10取模)加入新的链表节点,连接在返回链表后面,并继续往后遍历,并用总和对10除获取进位值
  3. 如果两个链表都遍历完成,cnt进位还有值,则补充创建一个节点,值为cnt

代码实现

给出代码实现基本档案

基本数据结构链表
辅助数据结构
算法迭代
技巧双指针

其中数据结构、算法和技巧分别来自:

  • 10 个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie 树
  • 10 个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法
  • 技巧:双指针、滑动窗口、中心扩散

当然包括但不限于以上

;
import java.util.*;/** public class ListNode {*   int val;*   ListNode next = null;*   public ListNode(int val) {*     this.val = val;*   }* }*/public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param head1 ListNode类* @param head2 ListNode类* @return ListNode类*/public ListNode addInList (ListNode head1, ListNode head2) {// 1 先将两个链表反转过来ListNode p1 = head1;ListNode p2 = head2;// 2 设置结果集以及初始化进位标识符ListNode dummy = new ListNode(-1);ListNode p = dummy;int cnt = 0;// 3 目标是遍历完两个链表的全部长度while (p1 != null || p2 != null) {// 3-1 获取当前节点值,如果是null节点则值为0int d1 = p1 == null ? 0 : p1.val;int d2 = p2 == null ? 0 : p2.val;// 3-2 计算总和、进位值、当前节点值int curSum = d1 + d2 + cnt;cnt = curSum / 10;p.next =  new ListNode(curSum % 10);// 3-3 结果指针移动,节点指针移动p = p.next;p1 = p1 == null ? null : p1.next;p2 = p2 == null ? null : p2.next;}// 4 全部结果如果遍历完,进位值还是大于0,则设置为最后一个节点if (cnt > 0) {p.next =  new ListNode(cnt);}return dummy.next;}
}

复杂度分析

时间复杂度:遍历链表,时间复杂度为O(N)
空间复杂度:不算返回的结果集的话,没有用到辅助空间,所以空间复杂度为O(1)

链表相加II【MID】

在这里插入图片描述

题干

进阶版,值为顺序,但链表是单向的,不能反过来遍历
在这里插入图片描述

解题思路

虽然链表不能反过来遍历,但是我们可以开始的时候就反转链表,然后返回结果时候再反转回去

  1. 任意一个链表为空,返回另一个链表就行了,因为链表为空相当于0,0加任何数为0,包括另一个加数为0的情况。
  2. 相继反转两个待相加的链表,反转过程可以参考反转链表。
  3. 设置返回链表的链表头,设置进位cnt=0.
  4. 从头开始遍历两个链表,直到两个链表节点都为空:
    1. 每次取出不为空的链表节点值,为空就设置为0
    2. 将两个数字与cnt相加,就是当前的总和
    3. 将总和(对10取模)加入新的链表节点,连接在返回链表后面,并继续往后遍历,并用总和对10除获取进位值
  5. 如果两个链表都遍历完成,cnt进位还有值,则补充创建一个节点,值为cnt
  6. 返回前将结果链表再反转回来。

代码实现

给出代码实现基本档案

基本数据结构链表
辅助数据结构
算法迭代
技巧双指针

其中数据结构、算法和技巧分别来自:

  • 10 个数据结构:数组、链表、栈、队列、散列表、二叉树、堆、跳表、图、Trie 树
  • 10 个算法:递归、排序、二分查找、搜索、哈希算法、贪心算法、分治算法、回溯算法、动态规划、字符串匹配算法
  • 技巧:双指针、滑动窗口、中心扩散

当然包括但不限于以上

;
import java.util.*;/** public class ListNode {*   int val;*   ListNode next = null;*   public ListNode(int val) {*     this.val = val;*   }* }*/public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可*** @param head1 ListNode类* @param head2 ListNode类* @return ListNode类*/public ListNode addInList (ListNode head1, ListNode head2) {// 1 先将两个链表反转过来ListNode p1 = reverse(head1);ListNode p2 = reverse(head2);// 2 设置结果集以及初始化进位标识符ListNode dummy = new ListNode(-1);ListNode p = dummy;int cnt = 0;// 3 目标是遍历完两个链表的全部长度while (p1 != null || p2 != null) {// 3-1 获取当前节点值,如果是null节点则值为0int d1 = p1 == null ? 0 : p1.val;int d2 = p2 == null ? 0 : p2.val;// 3-2 计算总和、进位值、当前节点值int curSum = d1 + d2 + cnt;cnt = curSum / 10;p.next =  new ListNode(curSum % 10);// 3-3 结果指针移动,节点指针移动p = p.next;p1 = p1 == null ? null : p1.next;p2 = p2 == null ? null : p2.next;}// 4 全部结果如果遍历完,进位值还是大于0,则设置为最后一个节点if (cnt > 0) {p.next =  new ListNode(cnt);}return reverse(dummy.next);}private ListNode reverse(ListNode head) {if (head == null) return null;ListNode pre = null;ListNode cur = head;while (cur != null) {ListNode pNext = cur.next;cur.next = pre;pre = cur;cur = pNext;}return pre;}
}

复杂度分析

时间复杂度:遍历链表,时间复杂度为O(N)
空间复杂度:不算返回的结果集的话,没有用到辅助空间,所以空间复杂度为O(1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/101961.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mybatis复杂查询及动态SQL

文章目录 一. 较复杂的查询操作1. 参数占位符#{}和${}2. SQL注入3. like查询4. resultType与resultMap5. 多表查询5.1. 一对一表映射5.2. 一对多表映射 二. 动态SQL1. if标签2. trim标签3. where标签4. set标签5. foreach标签 本篇中使用的数据表即基础映射类都是基于上一篇博客…

蓝牙服务功能

前言 这阵子用到蓝牙比较多,想写一个专栏专门讲解蓝牙协议及其应用,本篇是第二篇文章,讲解蓝牙服务。 参考网上各大神文章,及瑞萨的文章,参考GPT,并且加入了一些本人的理解。 图片部分源自网络&#xff…

Systrace分析App性能学习笔记

学习Gracker Systrace系列文章,总结使用Systrace分析App性能的方法。推荐想通过Systrace学习Framework的同学,去看原文。 文章目录 概述Systrace使用流程Systrace 文件生成图形方式(不推荐)命令行方式 Systrace分析快捷键使用帧状态线程状态查看线程唤醒…

Qt打开及创建项目,运行程序(1)

安装之后, 1.文件->新建文件或项目 2.Application->Qt Widgets Application 3.自己设置名称和路径 4.这一步非常非常重要,要选择编译器,(MinGW是可以在Qt里用,如果想与VS交互,要选择MSVC&#xff09…

Android签名查看

查看签名文件信息 第一种方法: 1.打开cmd,执行keytool -list -v -keystore xxx.keystore,效果如下图: 第二种方法: 1.打开cmd,执行 keytool -list -v -keystore xxxx.keystore -storepass 签名文件密码&#xff0…

YOLOV7改进-空洞卷积+共享权重的Scale-Aware RFE

代码 1、先把文件复制到common.py中 2、yolo.py添加类名 3、下半部分进行添加修改 4、cfg-training:新建配置文件 加了一行,后面对于序号1 5、这里选择12层替代

QT 第五天 TCP通信与数据库

一、数据库增删改查 QT core gui sqlgreaterThan(QT_MAJOR_VERSION, 4): QT widgetsCONFIG c11# The following define makes your compiler emit warnings if you use # any Qt feature that has been marked deprecated (the exact warnings # depend on your comp…

人工智能和大数据:跨境电商如何实现定制化营销?

在跨境电商竞争激烈的市场中,如何精准地满足消费者的需求并提供个性化的购物体验成为了商家们面临的重要挑战。幸运的是,人工智能和大数据技术的崛起为跨境电商带来了新的机遇,使得定制化营销成为可能。本文将探讨人工智能和大数据在跨境电商…

医院空调冷热源设计方案VR元宇宙模拟演练的独特之处

作为一个备受关注的技术-元宇宙,毋庸置疑的是,因为建筑本身契合了时尚、前卫、高端、虚拟、科幻、泛在、协作、互通等元素特征,因此在建筑行业更需要元宇宙,以居民建筑环境冷热源设计来说,元宇宙会打破既定的现实阻碍和…

AI绘画:StableDiffusion实操教程-斗罗大陆2-江楠楠-常服(附高清图下载)

前段时间我分享了StableDiffusion的非常完整的教程:“AI绘画:Stable Diffusion 终极宝典:从入门到精通 ” 尽管如此,还有读者反馈说,尽管已经成功安装,但生成的图片与我展示的结果相去甚远。真实感和质感之…

Linux系统——MySQL安装(CentOS7 超详细演示)

Linux系统安装MySQL MySQL8.0.26-Linux版安装1. 准备一台Linux服务器2. 下载Linux版MySQL安装包3. 上传MySQL安装包4. 创建目录,并解压5. 安装mysql的安装包6. 启动MySQL服务7. 查询自动生成的root用户密码8. 修改root用户密码9. 创建用户10. 并给root用户分配权限11. 通过Data…

超高真空度精密控制解决方案设计中百度“文心一言”的具体应用

摘要:本文采用国产版本ChatGPT百度“文心一言”作为一种辅助工具,针对超高真空度精密控制装置的开发进行了初期的技术路线设计,对话调研的重点是了解可调节式微流量进气阀门和可用于连接非线性输出信号型真空计的PID控制器。总体而言&#xf…