当前位置: 首页 > news >正文

代码随想录算法训练营第四天| 24. 两两交换链表中的节点、19.删除链表的倒数第N个节点 、 面试题 02.07. 链表相交、142.环形链表II

24. 两两交换链表中的节点

在这里插入图片描述

题目链接: 24. 两两交换链表中的节点
文档讲解:代码随想录
状态:没做出来,没有正确更新头节点,因为head和cur共享引用,会随着cur的移动,丢失之前存放的节点

错误代码:

    public ListNode swapPairs(ListNode head) {ListNode cur = head;ListNode next;ListNode temp;while (cur != null && cur.next != null) {next = cur.next;temp = next.next;next.next = cur;cur.next = temp;cur = temp;}return head;}

思路:前面博客中总结过啥时候需要使用虚拟头结点,这边需要返回head节点,所以使用dummy节点,然后cur从dummy出发。

public ListNode swapPairs(ListNode head) {// 创建一个虚拟节点,dummy.next 指向 headListNode dummy = new ListNode();dummy.next = head;// cur 用于遍历链表,初始化为 dummy 节点ListNode cur = dummy;ListNode first;   // 用于指向要交换的第一个节点ListNode second;  // 用于指向要交换的第二个节点ListNode temp;    // 用于暂存第二个节点的下一个节点// 当 cur 后面至少有两个节点时,继续交换while (cur.next != null && cur.next.next != null) {first = cur.next;          // 定位要交换的第一个节点second = cur.next.next;    // 定位要交换的第二个节点temp = second.next;        // 暂存第二个节点的下一个节点// 进行节点交换first.next = temp;         // 第一个节点的 next 指向第二个节点的 nextsecond.next = first;       // 第二个节点的 next 指向第一个节点cur.next = second;         // 当前节点的 next 指向第二个节点// cur 移动到已交换的两个节点之后的位置cur = first;}// 返回新的头节点return dummy.next;
}

19.删除链表的倒数第N个节点

在这里插入图片描述

题目链接: 19.删除链表的倒数第N个节点
文档讲解:代码随想录
状态:so easy

思路:
看到“返回链表的头结点”,使用虚拟头结点dummy,删除倒数第N个节点就需要先找到它,然后对它进行操作。
方式1:遍历一遍得到len,然后倒数第n个节点就是len-n+1个节点。
方式2:利用栈,先所有节点入栈,然后出栈n个节点,此时栈顶元素就是倒数第N+1个节点,让它的next节点指向下下个节点即可。
方式3:利用双指针中的快慢指针,让fast指针先走n步,然后和slow指针同时移动,当fast指针指向null时,slow指针指向倒数第N=1个节点,让它的next节点指向下下个节点即可。

双指针题解

public ListNode removeNthFromEnd(ListNode head, int n) {// 创建一个虚拟节点,dummy.next 指向 headListNode dummy = new ListNode();dummy.next = head;// 初始化快指针和慢指针都指向虚拟节点ListNode fast = dummy;ListNode slow = dummy;// 让快指针先移动 n 步while (n-- > 0 && fast.next != null) {fast = fast.next;}// 同时移动快指针和慢指针,直到快指针到达链表末尾while (fast.next != null) {fast = fast.next;slow = slow.next;}// 慢指针的下一个节点就是要删除的节点slow.next = slow.next.next;// 返回新的头节点return dummy.next;}

面试题 02.07. 链表相交

在这里插入图片描述

题目链接: 面试题 02.07. 链表相交(同160.链表相交)
文档讲解:代码随想录
状态:没做出来,一个bug卡了很久。

错误代码:

    // 在每一轮循环中,指针先移动到下一个节点,然后才判断是否为null并进行重定向。这会导致在指针都为null时直接重定向,而没有机会检查pointerA == pointerB是否成立,导致死循环。public ListNode getIntersectionNode(ListNode headA, ListNode headB) {ListNode pointerA = headA;ListNode pointerB = headB;while (pointerA != pointerB) {pointerA = pointerA.next;pointerB = pointerB.next;if (pointerA == null) {pointerA = headB;}if (pointerB == null) {pointerB = headA;}}return pointerA;}

思路1:可以使用HashMap,headA中的节点都存在map中,遍历headB时检查是否在map中存在该节点。如果存在,则这个节点就是交点
思路2:双指针。pA遍历headA,pB遍历headB,当pA遍历到尾部时,重定向到headB,当pB遍历到尾部时,重定向到headA,如果存在相同节点,则会两个指针在同一个节点相遇。

双指针题解:

   /*** 法二:双指针* 指针 pA和pB 指向同一个节点或者都为空时,返回它们指向的节点或者 null* <p>这边指向相同节点的是8,不是5也不是1哦,前面的5和1只是值相等,地址不等* 4 1 8 4 5#5 0 1 8 4 5* 5 0 1 8 4 5#4 1 8 4 5*/public ListNode getIntersectionNode(ListNode headA, ListNode headB) {// 初始化两个指针,分别指向两个链表的头节点ListNode pA = headA;ListNode pB = headB;// 遍历两个链表,直到找到交点或者遍历结束while (pA != pB) {// 如果当前指针不为空,则移动到下一个节点;否则,重定向到另一个链表的头部pA = (pA != null) ? pA.next : headB;pB = (pB != null) ? pB.next : headA;}// 返回交点的节点,如果没有交点则返回nullreturn pA;}

142.环形链表II

在这里插入图片描述

题目链接: 142.环形链表II
文档讲解:代码随想录
状态:还行

思路1:遍历head节点,用HashSet检查是否有出现过的同一节点,如果没有,就将遍历到的节点存入HashSet,否则返回的节点就是环的入口节点
思路2:数学方法+快慢指针

快慢指针题解

 // 使用快慢指针法找到单链表中的环的入口点public ListNode detectCycle(ListNode head) {// 初始化快慢指针,初始位置为链表头部ListNode fast = head, slow = head;// 防止空链表或者不存在环的情况while (true) {// 如果快指针或者快指针的下一个节点为null,说明不存在环,返回nullif (fast == null || fast.next == null) {return null;}// 快指针每次移动两步,慢指针每次移动一步fast = fast.next.next;slow = slow.next;// 如果快慢指针相遇,说明存在环,跳出循环if (fast == slow) {break;}}// 将快指针重新指向链表头部,慢指针不变fast = head;/*当快慢指针再次相遇时,即为环的入口点这是因为在快慢指针相遇时,慢指针走过的距离(从链表头到环入口点的距离)与快指针走过的距离之间存在一定的关系。假设链表头到环入口点的距离为A,快慢指针相遇点距离环入口点的距离为B,环的周长为C。当快慢指针相遇时,快指针已经在环内绕了n圈,所以慢指针走的距离是(A+ B),而快指针走的距离是(A+B+nC)。由于快指针是慢指针的两倍速度,因此有关系:快指针走过的距离是慢指针的两倍。可以得到以下方程:A+B+nC=2(A+B)从而可以推导出:A= (n-1)C+(C-B)这意味着,将快指针重新指向链表头部,然后慢指针和快指针以相同的速度前进,它们将在环的入口点相遇。这是因为,慢指针走了n—1圈的环,再走C—B的距离就到达了环的入口点,而根据公式,同样的速度快指针从链表头步出发,此时刚好也走了距离A,此时两个指针在入口点相遇*/while (slow != fast) {slow = slow.next;fast = fast.next;}// 返回环的入口点return fast;}

相关文章:

代码随想录算法训练营第四天| 24. 两两交换链表中的节点、19.删除链表的倒数第N个节点 、 面试题 02.07. 链表相交、142.环形链表II

24. 两两交换链表中的节点 题目链接&#xff1a; 24. 两两交换链表中的节点 文档讲解&#xff1a;代码随想录 状态&#xff1a;没做出来&#xff0c;没有正确更新头节点&#xff0c;因为head和cur共享引用&#xff0c;会随着cur的移动&#xff0c;丢失之前存放的节点 错误代码&…...

吉林大学计科21级《软件工程》期末考试真题

文章目录 21级期末考试题一、单选题&#xff08;2分一个&#xff0c;十个题&#xff0c;一共20分&#xff09;二、问答题&#xff08;5分一个&#xff0c;六个题&#xff0c;一共30分&#xff09;三、分析题&#xff08;一个10分&#xff0c;一共2个&#xff0c;共20分&#xf…...

AWS云服务器每月费用高昂,如何优化达到节省目的?

AWS云服务器每月费用可能因不同的使用情况和配置而有所不同。为了优化并节省AWS云服务器的费用&#xff0c;aws的合作伙伴九河云提供了一些建议&#xff1a; &#xff08;1&#xff09;调整实例大小&#xff1a;确保你使用的实例大小与你的工作负载相匹配。实例的容量每增加一倍…...

关于XtremIO 全闪存储维护的一些坑(建议)

XtremIO 是EMC过去主推的一款全闪存储系统&#xff0c;号称性能小怪兽&#xff0c;对付那些对于性能要求极高的业务场景是比较合适的&#xff0c;先后推出了1代和2代产品&#xff0c;目前这个产品好像未来的演进到了PowerStor或者PowerMax全闪&#xff0c;应该不独立发展这个产…...

《最新出炉》系列入门篇-Python+Playwright自动化测试-41-录制视频

宏哥微信粉丝群&#xff1a;https://bbs.csdn.net/topics/618423372 有兴趣的可以扫码加入 1.简介 上一篇讲解和分享了录制自动生成脚本&#xff0c;索性连带录制视频也一股脑的在这里就讲解和分享了。今天我们将学习如何使用Playwright和Python来录制浏览器操作的视频&#…...

一个程序员的牢狱生涯(38)答案

星期一 答 案 我被这个不知道什么时候无声无息的出现在身后的人吓出了一身的冷汗。 看到我发现了他,这个人慢慢地抬起了头……“他X的,是小X州!” 此时的小X州脸上并没有着急等待上厕所的表情,反而是用一种狡黠的眼神看着我。一直充满的敌意,现在又多了一丝威胁的神情,让…...

MySQL命令

目录 1、初级 一、连接和退出 1. 连接到 MySQL 2. 退出 MySQL 二、数据库操作 1. 显示数据库列表 2. 创建数据库 3. 使用数据库 4. 删除数据库 三、表操作 1. 显示当前数据库中的表 2. 创建表 3. 查看表结构 4. 删除表 5. 修改表 四、数据操作 1. 插入数据 2.…...

装本地知识库

装本地知识库 给大模型添加RAG知识库和搜索的功能 1.安装phidata pip install -U phidata在github将该项目拉取下来&#xff0c;后续步骤的很多内容可以直接使用该项目中给的例子&#xff0c;进行简单修改就可直接使用。 2.安装向量知识库&#xff0c;使用的docker docker …...

Django模板层——模板引擎配置

作为Web 框架&#xff0c;Django 需要一种很便利的方法以动态地生成HTML。最常见的做法是使用模板。 模板包含所需HTML 输出的静态部分&#xff0c;以及一些特殊的语法&#xff0c;描述如何将动态内容插入。 模板引擎配置 模板引擎使用该TEMPLATES设置进行配置。这是一个配置列…...

Leetcode刷题笔记2:数组基础2

导语 leetcode刷题笔记记录&#xff0c;本篇博客记录数组基础1部分的题目&#xff0c;主要题目包括&#xff1a; 977.有序数组的平方 &#xff0c;209.长度最小的子数组 &#xff0c;59.螺旋矩阵II 知识点 滑动窗口 所谓滑动窗口&#xff0c;就是不断的调节子序列的起始位…...

整理好了!2024年最常见 20 道 Redis面试题(八)

上一篇地址&#xff1a;整理好了&#xff01;2024年最常见 20 道 Redis面试题&#xff08;七&#xff09;-CSDN博客 十五、Redis 的性能调优有哪些方法&#xff1f; Redis的性能调优是一个多方面的工作&#xff0c;涉及到硬件、配置、代码层面的优化等多个方面。以下是一些常…...

【STM32项目】基于stm32智能鱼缸控制系统的设计与实现(完整工程资料源码)

实物演示效果 基于stm32智能鱼缸控制系统的设计与实现 目录: 实物演示效果 目录: 一、 绪论...

深入理解 Mysql 分层架构:从存储引擎到查询优化器的内部机制解析

一、基础架构 1.连接器 1.会先连接到这个数据库上&#xff0c;这时候接待你的就是连接器。连接器负责跟客户端建立连接、获取权限、维持和管理连接 2.用户密码连接成功之后&#xff0c;会从权限表中拿出你的权限&#xff0c;后续操作权限都依赖于此时拿出的权限,这就意味着当链…...

Java筑基(三)

Java筑基&#xff08;三&#xff09; 一、final概念1、案例1&#xff1a;采用继承&#xff1a;2、案例2&#xff1a;final修饰的类不可以被继承&#xff1a;3、案例3&#xff1a;final修饰的类不能有子类&#xff0c;但是可以有父类4、final修饰构造方法5、final修饰普通方法6、…...

Zoho Campaigns邮件营销怎么发邮件?

Zoho Campaigns&#xff0c;作为业界领先的邮件营销平台&#xff0c;以其强大的功能、用户友好的界面以及深度的分析能力&#xff0c;为企业提供了一站式的邮件营销解决方案&#xff0c;助力企业高效地触达目标受众&#xff0c;构建并巩固庞大的客户基础。云衔科技为企业提供Zo…...

Qt 界面上字体自适应控件大小 - 随控件缩放

Qt 界面上字体自适应控件大小 - 随控件缩放 引言一、设计思路二、进阶版大致思路三、参考链接 引言 Qt控件自适应字体大小可以用adjustSize()函数&#xff0c;但字体自适应控件大小并没有现成的函数可调. - 本文实现了按钮上的字体随按钮大小变化而变化 (如上图所示) - 其他控件…...

【Python】 使用SMOTE解决数据不平衡问题

原谅把你带走的雨天 在渐渐模糊的窗前 每个人最后都要说再见 原谅被你带走的永远 微笑着容易过一天 也许是我已经 老了一点 那些日子你会不会舍不得 思念就像关不紧的门 空气里有幸福的灰尘 否则为何闭上眼睛的时候 又全都想起了 谁都别说 让我一个人躲一躲 你的承诺 我竟然没怀…...

Redis第18讲——Redis和Redission实现延迟消息

即使不是做电商业务的同学&#xff0c;也一定知道订单超时关闭这种业务场景&#xff0c;这个场景大致就是用户下单后&#xff0c;如果在一定时间内未支付&#xff08;比如15分钟、半小时&#xff09;&#xff0c;那么系统就会把这笔订单给关闭掉。这个功能实现的方式有很多种&a…...

返回枚举类给前端

1. 前言 在实际开发过程中&#xff0c;前端的下拉框或者单选按钮的内容通常的需要和后端匹配的&#xff0c;故一般会由后端将下拉框的内容或单选框的内容传给前端&#xff0c;而这些内容在后端一般是由枚举类存储的&#xff0c;如果后端直接返回枚举类&#xff0c;返回结果将会…...

A. Maximize?

time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standard output You are given an integer x&#x1d465;. Your task is to find any integer y&#x1d466; (1≤y<x)(1≤&#x1d466;<&#x1d465;) su…...

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇&#xff0c;在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下&#xff1a; 【Note】&#xff1a;如果你已经完成安装等操作&#xff0c;可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作&#xff0c;重…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

解锁数据库简洁之道:FastAPI与SQLModel实战指南

在构建现代Web应用程序时&#xff0c;与数据库的交互无疑是核心环节。虽然传统的数据库操作方式&#xff08;如直接编写SQL语句与psycopg2交互&#xff09;赋予了我们精细的控制权&#xff0c;但在面对日益复杂的业务逻辑和快速迭代的需求时&#xff0c;这种方式的开发效率和可…...

Nuxt.js 中的路由配置详解

Nuxt.js 通过其内置的路由系统简化了应用的路由配置&#xff0c;使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

C# 类和继承(抽象类)

抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...

【分享】推荐一些办公小工具

1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由&#xff1a;大部分的转换软件需要收费&#xff0c;要么功能不齐全&#xff0c;而开会员又用不了几次浪费钱&#xff0c;借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...

08. C#入门系列【类的基本概念】:开启编程世界的奇妙冒险

C#入门系列【类的基本概念】&#xff1a;开启编程世界的奇妙冒险 嘿&#xff0c;各位编程小白探险家&#xff01;欢迎来到 C# 的奇幻大陆&#xff01;今天咱们要深入探索这片大陆上至关重要的 “建筑”—— 类&#xff01;别害怕&#xff0c;跟着我&#xff0c;保准让你轻松搞…...

解决:Android studio 编译后报错\app\src\main\cpp\CMakeLists.txt‘ to exist

现象&#xff1a; android studio报错&#xff1a; [CXX1409] D:\GitLab\xxxxx\app.cxx\Debug\3f3w4y1i\arm64-v8a\android_gradle_build.json : expected buildFiles file ‘D:\GitLab\xxxxx\app\src\main\cpp\CMakeLists.txt’ to exist 解决&#xff1a; 不要动CMakeLists.…...

tomcat入门

1 tomcat 是什么 apache开发的web服务器可以为java web程序提供运行环境tomcat是一款高效&#xff0c;稳定&#xff0c;易于使用的web服务器tomcathttp服务器Servlet服务器 2 tomcat 目录介绍 -bin #存放tomcat的脚本 -conf #存放tomcat的配置文件 ---catalina.policy #to…...

前端开发者常用网站

Can I use网站&#xff1a;一个查询网页技术兼容性的网站 一个查询网页技术兼容性的网站Can I use&#xff1a;Can I use... Support tables for HTML5, CSS3, etc (查询浏览器对HTML5的支持情况) 权威网站&#xff1a;MDN JavaScript权威网站&#xff1a;JavaScript | MDN...