【LeetCode】二、链表相关:移除与反转链表

文章目录

  • 1、链表结构
  • 2、leetcode203:移除链表元素
  • 3、leetcode206:反转链表

1、链表结构

和数组不同,此时不需要连续的内存空间,如下为单端链表,无pre指针
在这里插入图片描述
时间复杂度:

在这里插入图片描述

和数组相反,访问元素时不能再直接计算出对应下标的内存地址,时间复杂度变为O(N),但插入和删除不用再前移或后移受影响的全部元素,而是只需要修改对应位置的next指针指向,因此单这个操作的时间复杂度为O(1),但其实插入和删除前得先从头开始遍历到对应位置的元素,因此,时间复杂度整体为O(n),适用于读少写多的场景

2、leetcode203:移除链表元素

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回新的头节点 。
在这里插入图片描述
思路:

  • 传入起始头节点,在没到尾节点之前(next为null即到尾节点,node为null说明尾节点也处理完了),一直head=head.next往下遍历

  • 如果不满足head.val==val,则继续往下遍历

  • 满足则让当前节点head的前一个节点指向head.next,完成删除,但当前为单向链表,获取不到前一个节点,因此需要维护一个pre node的值,记录遍历到的当前节点的head的前一个节点,以便进行删除操作

  • 此外,要求最后返回新的头节点,只靠一直往下移动的pre和head,遍历完后,无法获得头节点信息(单向链表),因此还要加一个虚拟节点dummy(位置在传入的head的前一个节点),dummy的next等于传入的头节点,dummy的val则随便给,反正用不到
    在这里插入图片描述
    在这里插入图片描述

  • 刚开始时,虚拟节点赋值给pre,如此,即使传入的头节点就符合要求被删了,那pre的next指向第二个节点,也即虚拟节点的next指向第二个节点,如此能保证dummy.next始终为新的头节点

  • 反之,传入的头节点不被删,那pre和head往下走,判断下一个节点,此时就不关虚拟节点的事了,它只是记录了头节点信息

Java实现:

//链表节点类
public class ListNode {int val;ListNode next;public ListNode() {}public ListNode(int val, ListNode next) {this.val = val;this.next = next;}@Overridepublic String toString() {return "ListNode{" +"val=" + val +", next=" + next +'}';}
}

移除的实现:

public class P203 {public static ListNode removeElements(ListNode head, int val) {ListNode dummyNode = new ListNode(0, head);// 刚开始时,head节点的前一个节点为虚拟节点dummyNodeListNode prev = dummyNode;while (head != null && head.next != null) {if (head.val == val) {prev.next = head.next;//head再向下移一位head = head.next;} else {prev = head;head = head.next;}}return dummyNode.next;}
}

测试:

public class P203 {public static void main(String[] args) {ListNode tailNode = new ListNode(1, null);ListNode node4 = new ListNode(2, tailNode);ListNode node3 = new ListNode(2, node4);ListNode node2 = new ListNode(1, node3);ListNode node1 = new ListNode(0, node2);ListNode head = new ListNode(9, node1);ListNode listNode = removeElements(head, 9);System.out.println(listNode.val);System.out.println(listNode.next);}}

在这里插入图片描述

3、leetcode206:反转链表

在这里插入图片描述
思路:如上,先把2移动到1的前面,再把3移动到2的前面,再把4移动到3的前面

在这里插入图片描述

//链表节点类
public class ListNode {int val;ListNode next;public ListNode() {}public ListNode(int val, ListNode next) {this.val = val;this.next = next;}@Overridepublic String toString() {return "ListNode{" +"val=" + val +", next=" + next +'}';}
}

倒装函数的实现:

public class P206 {public static ListNode reverse(ListNode head) {ListNode dummy = new ListNode(0, head);while (head != null && head.next != null) {ListNode moveNode = head.next;ListNode currentHeadNode = dummy.next;//虚拟节点改为指向要移动的节点dummy.next = moveNode;//原来的头节点改为指向下一个待移动的节点head.next = head.next.next;//要移动的节点改为指向移动后的第一个节点(虚拟节点的下一个节点)moveNode.next = currentHeadNode;}return dummy.next;}
}

测试:

public class P206 {public static void main(String[] args) {ListNode tailNode = new ListNode(6, null);ListNode node4 = new ListNode(5, tailNode);ListNode node3 = new ListNode(4, node4);ListNode node2 = new ListNode(3, node3);ListNode node1 = new ListNode(2, node2);ListNode head = new ListNode(1, node1);ListNode listNode = reverse(head);System.out.println(listNode.val);System.out.println(listNode.next);}}

在这里插入图片描述

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

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

相关文章

Jackson和fastjson解决序列化时字段属性大小写改变的问题

在部分特殊场景下,我们可能会把实体的字段属性改成全部大写,但是在返回前端时,字段会被序列化成小写。 比如我们有一个这个类属性都是大写: 后端接口是这样的 然后我们请求后,会发现我们的字段被变成全部小写的。 …

linux服务器解压/压缩文件

在Linux服务器上,可以使用zip和tar命令来进行文件的打包(压缩)和解包(解压缩)。下面是它们的基本用法: 打包(压缩)与解压方法: 1. 使用 zip 命令 打包成 .zip 文件&am…

Java面试题:讨论如何使用JVM工具(如jconsole、jstack、jmap)诊断内存泄漏

诊断Java应用程序中的内存泄漏可以使用JVM提供的多种工具,如jconsole、jstack和jmap。这些工具可以帮助开发者监控和分析Java应用程序的运行状况,定位内存泄漏的根源。以下是这些工具的详细介绍及其使用方法: 1. jconsole JConsole&#xf…

CCAA:认证通用基础 7(认证的基本概念)

7认证的基本概念 7.1认证类型(产品认证、管理体系认证、服务认证)及基本特征 第一节 认证 1.认证的定义和本质 1.1认证的定义 (1)认证:与产品、过程、体系或人员有关的第三方证明。 ①”产品,过程,体系或人员”是认证的对象,认证是对“产…

PyQt6+mitmproxy,实现抓取网络请求并打印到桌面的窗口中

你可以将你的PyQt6应用程序与mitmproxy结合使用,以便在GUI中显示拦截的HTTP请求和响应。以下是修改后的代码: 安装依赖项: 确保你已经安装了PyQt6和mitmproxy: pip install PyQt6 mitmproxy编写Python代码: 创建一个Py…

软考中级:信息系统管理工程师备考资源

信息系统管理工程师备考资源 1 备考资源内容2 使用心得3 资源地址 1 备考资源内容 资源内容包含三部分:教程书籍pdf、备考笔记、历年真题 可以结合“软考通”APP进行练习备考,无偿分享。 2 使用心得 上面的资源很多,可以先从复习笔记开…

Kotlin作用域函数it和with的使用场景

在 Kotlin 中,apply、run、with 使用 this,而 let 和 also 使用 it,这背后的原因是为了提供灵活性和代码清晰度。不同的作用域函数有不同的设计目的,选择使用 this 或 it 是为了适应不同的使用场景。以下是详细解释: …

如何提高工业交换机的电源功耗?

工业交换机的电源功耗是指在工作状态下所消耗的能量。随着工业自动化技术的发展,工业交换机在生产和制造领域中扮演着至关重要的角色。它们通过连接各种设备和系统,实现信息的传输和处理,提高生产效率和质量。然而,工业交换机的大…

高质量3d建模素材网站推荐,建议收藏!

很多设计师、建模师想要制作出高质量的3D模型,除了扎实的技巧和丰富的经验外,还需要大量的高质量素材。那么到哪里去找高质量3d建模素材网站呢?本文将给大家推荐一些,建议收藏! 1、建e网:建e网是一个专注于为建筑、室内、景观设计…

郑州大学人工智能简答

第一章 1. 什么是人工智能? 人工智能又称机器智能,主要研究人工的方法和技术开发智能机器或智能系统,以模仿、延伸和扩展人的智能、生物智能、自然智能,实现机器的智能行为。 人工智能的定义分四类: (1&am…

ai语音智能电销机器人的运用有哪些,呼叫系统部署

现在智能电销机器人仍是很火,智能电销机器人的运用有哪些,到底有什么效果?智能电销机器人运用有哪些了,我们一起来看看 1、确保心情丰满。电销人员在作业中,会由于作业比较单调而导致心情烦躁,不能确保全天…

Java--乐观锁

乐观锁是一种并发控制机制,用于处理多个事务或线程对同一数据进行并发修改的问题。它假设多个事务或线程在操作数据时不会互相干扰,因此不在数据上加锁,而是在提交数据时检查数据是否被其他事务修改过。如果数据在提交前已经被其他事务修改&a…

政务网站(.gov)应选择什么样的SSL证书

政府网站作为公共服务的重要平台,承载着发布政策信息、提供在线服务、促进政民互动等功能,其数据安全性和网站可信度尤为重要。因此,选择合适的SSL证书对于政府网站而言,不仅是遵循网络安全法规的需要,也是提升公众信任…

【ai】trition:tritonclient yolov4:ubuntu18.04部署python client成功

X:\05_trition_yolov4_clients\01-python server代码在115上,client本想在windows上, 【ai】trition:tritonclient.utils.shared_memory 仅支持linux 看起来要分离。 【ai】tx2 nx:ubuntu18.04 yolov4-triton-tensorrt 成功部署server 运行 client代码远程部署在ubuntu18.0…

微服务架构设计关键点总结

1.微服务架构设计通用语言 2.微服务架构组成 NFRS(非功能性需求)补充 3.DDD 省略 4.其他 Backend for frontend (BFF) pattern: 针对不同的客户端定义不同的api gateway API组合模式:一次性返回关联后的结果 eg:ap…

优思学院|精益生产3大特征、5个步骤、8大浪费、10大工具

前言 精益生产作为一种先进的生产管理理念,起源于丰田汽车公司的生产方式,其核心在于消除浪费、优化流程,以最少的投入获取最大的产出。本文将详细解析精益生产的三大特征、五个步骤、八大浪费和十大工具,帮助读者深入理解这一理…

ubuntu 18 虚拟机安装(2)

ubuntu 18 虚拟机安装(2) ● Ubuntu版本查看 lsb_release -a ● mysql 版本查看 mysql --version 安装 vi 安装vim: ubuntu预装的是vim tiny版本,而需要的是vim full版本。执行下面的语句安装vim full版本: $su…

威纶通模板元件功能使用,重复调用模板界面

目录 STEP 1 定义模板范围STEP 2 创建地址STEP 3 新建模板STEP 4 调用模板STEP 5 仿真测试 STEP 1 定义模板范围 选择元件-模板窗口 定义模板窗口范围 这是将窗口20-30定义为模板窗口 STEP 2 创建地址 定义几个标签地址,这里关联的内部地址 如果使用外部PLC地址…

【知识学习】Unity3D——Surface Shaderlightning的概念及使用方法示例

Unity3D是一个广泛使用的跨平台游戏引擎,它提供了强大的图形渲染功能。在Unity中,Shader是用于控制图形渲染过程的程序,它们运行在GPU上,用于计算屏幕上每个像素的颜色。Surface Shader和Lighting是Unity Shader编程中非常重要的概…