图解LeetCode链表题

news/2024/11/25 0:33:22/

💐文章导读

本篇文章主要详细的用图解的方式为大家讲解了简单程度的链表题,如果题中有错误的地方,还麻烦您在评论区指出,你的意见就是我最大的进步!!!

💐专栏导读

🤴作者:🦁努力努力再努力

🏆文章专栏:🌷《JavaSE语法》 、 🌷《C语言初阶》、 🌷《图解LeetCode》、 🌺《数据结构剖析》

文章目录

  • 💐文章导读
  • 💐专栏导读
  • 1、环形链表
  • 2.环形链表进阶版
  • 3.相交链表
  • 4.删除排序链表中的重复元素
  • 5.移除重复节点
  • 6.删除中间节点
  • 7.二进制链表转整数
  • 9.翻转链表
  • 10.链表中倒数第K个结点
  • 11.从头到尾打印链表

1、环形链表

思路:本体主要是利用双指针进行解题,分别定义一个快指针和慢指针,快指针一次走两步,慢指针一次走一步,如果链表有环的情况下,快慢指针直接差的距离最多是一个环的距离,肯定不会超过一个环,所以就需要用一个循环让快慢指针分别走,当两个指针相遇时,就返回true,就表明链表有环,如果循环结束了还没有返回,就表明链表没环,而循环结束的条件就是fast==null || fast.next == null时,表明链表已经走完了。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

2.环形链表进阶版

在这里插入图片描述

在这里插入图片描述

    public ListNode detectCycle(ListNode head) {if(head == null) {return null;}ListNode fast = head;ListNode slow = head;while(fast!=null && fast.next!=null) {//查找在环中相遇时的节点fast = fast.next.next;slow = slow.next;if(fast == slow){break;}}if( fast==null || fast.next==null) {return null;}fast = head;while(fast != slow){fast = fast.next;slow = slow.next;}return fast;}

3.相交链表

在这里插入图片描述

思路:

如果要求两个链表的在什么地方相交,就要从两个链表的同一个节点向后遍历,所以首先要算出两个链表的长度差,让长的链表向后先走差值步,然后两个链表再一起向后走,直到遇见相同的地址处!

下面有图解:

public ListNode getIntersectionNode(ListNode headA, ListNode headB) {//1、分别求2个链表的长度int lenA = 0;int lenB = 0;int len = 0;ListNode curA = headA;ListNode curB = headB;while(curA != null) {lenA++;curA = curA.next;}while(curB != null) {lenB++;curB = curB.next;}curA = headA;curB = headB;len = lenA-lenB;if(len<0) {curA = headB;curB = headA;len = lenB-lenA;}for(int i=0; i<len; i++) {curA = curA.next;}while(curA!= null && curB!=null) {if(curA == curB){return curA;}curA = curA.next;curB = curB.next;} return null;}

在这里插入图片描述

在这里插入图片描述

4.删除排序链表中的重复元素

在这里插入图片描述

在这里插入图片描述

5.移除重复节点

在这里插入图片描述

双指针解法:
定义一个cur1指向头节点,再定义一个cur2指向cur1,用cur2区遍历所有的节点中val值与cur1中的val值作对比,如果相同就删除,否则就一直遍历

  public ListNode removeDuplicateNodes(ListNode head) {if(head == null) {return null;}ListNode cur1 = head;while(cur1 != null){ListNode cur2 = cur1;while(cur2.next != null){if(cur2.next.val == cur1.val) {cur2.next = cur2.next.next;}else{cur2 = cur2.next;}}cur1 = cur1.next;}return head;}

在这里插入图片描述

6.删除中间节点

在这里插入图片描述

解题思路:

要删除中间节点的话本来应该要找到中间节点的前驱的,但是现在只给了中间节点,那么可以这样做,可以把中间节点的后继节点中的val值赋给中间节点的val值,然后把后继节点删除掉,这样也符合题目要求

 public void deleteNode(ListNode node) {node.val = node.next.val;node.next = node.next.next;}

7.二进制链表转整数

在这里插入图片描述

   //第一种方法:利用按位或
public int getDecimalValue(ListNode head) {int ans = 0;ListNode cur = head;while(cur != null) {ans  = ans<<1;ans |= cur.val;cur = cur.next;}return ans;}
//第二种方法:利用换算二进制方法public int getDecimalValue(ListNode head){ListNode cur = head;int ans = 0;while(cur != null) {ans = ans*2+cur.val;cur = cur.next;}return ans;}

在这里插入图片描述

9.翻转链表

在这里插入图片描述

解题思路:

1、翻转链表就是将后面的每一个节点都存储前面一个节点的地址

2、因为链表都是从前向后走的,如果想要让后一个节点cur中的next变成前一个节点的地址,就需要知道前一个节点的地址;所以需要用一个变量prev来记录前一个结点,再用一个变量next来记录第三个结点,以方便中间的节点向后走,不然的话,当中间节点内的next改变以后,没办法找到第三个节点的位置,然后三个记录节点的变量分别向后走,这样知道前面一个节点和后面一个节点,就可以进行翻转!

   public ListNode reverseList(ListNode head) {if(head == null) {return null;}ListNode curprev = null;ListNode cur = head;while(cur != null) {ListNode next = cur.next;cur.next = curprev;curprev = cur;cur = next;}head = curprev;return head;}

10.链表中倒数第K个结点

在这里插入图片描述

解题思路:

1、求链表中倒数第K个结点,应该思考当给过k之后,应该怎么找这个倒数第k个节点,就拿题中给的事例来说,求倒数第二个结点就是4,可以用快慢指针的方法,而快慢指针的概念就是,假如有两个人A和B,它们都距离目的地差10步,如果让A先提前走三步,那么A和B之间就会差三步,然后让A和B在一人一步走,这样当A走到目的地时,B还是和A差三步远,而这个B正好在倒数第三个位置。路程不同,时间相同,速度相同,最后得到的就是路程差

所以此题定义一个fast快指针和slow慢指针,让快指针先走k步,当快指针走到空时,满指针正好在倒数第k的位置

 public ListNode getKthFromEnd(ListNode head, int k) {if(head == null) {return null;}ListNode fast = head;ListNode slow = head;for(int i =0; i<k; i++) {fast =fast.next;}while(fast != null) {fast = fast.next;slow = slow.next;}return slow;}

11.从头到尾打印链表

在这里插入图片描述

解题方法:

1、先计算链表的长度,作为数组的长度

2、判断链表是否为空,为空则数组也为空,返回空数组

3、从数组的最后的下标开始放链表中的val

    public int[] reversePrint(ListNode head) {int len = 0;ListNode cur = head;//计算链表的长度while(cur!=null){len++;cur = cur.next;}int[] arr = new int[len];//如果链表为空则返回空数组if(head == null) {return arr;}因为数组下标是从0开始的所以减一int i =len-1;cur = head;while(cur!=null) {//从数组的最后开始放arr[i--] = cur.val;cur = cur.next;}return arr;}

http://www.ppmy.cn/news/83548.html

相关文章

CC++ 标头和源文件:它们如何工作?

本文将向您展示将程序划分为C中的组件部分或正确使用标头和源文件C诀窍。 介绍 我主要是为我的一个朋友写这篇文章的。但是&#xff0c;如果我不与大家分享这一点&#xff0c;我会对社区造成伤害&#xff0c;所以就在这里。 我们将探索标头和源文件以及它们的作用。这些代码…

一文搞定验证码(下部分)

文章目录 1.背景2.验证3.valid接口具体实现类SimpleImageCaptchaValidator 1.背景 上一篇文章讲了验证码生成的逻辑. 验证码-上篇. 大概来说就是: 服务端保存一些默认的验证码图片. 然后需要生成时创建一个包含随机字符的验证码字符图片根据随机字符和一些参数&#xff08;如…

三、Go的常用命令以及Go的执行原理

Go的执行原理以及Go的命令 一、Go的源码文件 Go 的源码文件分类&#xff1a; 如上图&#xff0c;分为三类&#xff1a; 1、命令源码文件&#xff1a; 声明自己属于 main 代码包、包含无参数声明和结果声明的 main 函数。 命令源码文件被安装以后&#xff0c;GOPATH 如果…

C++可变模板参数的使用

最近在封装打印函数&#xff0c;需要支持不同参数个数和类型&#xff0c;用了函数重载感觉有点麻烦且不太能满足所有的条件。研究了一下C11的新特性可变模板参数 模板定义&#xff1a;声明可变参数模板时需要在typename或class后面带上省略号“…”。 template <class… T&…

中国人民大学与加拿大女王大学金融硕士——在职人员成长路上的选择与追求

在职人员职场充电&#xff0c;选择中国人民大学与加拿大女王大学金融硕士项目是正确的吗&#xff1f;其实每个选择都有各自的收获和代价&#xff0c;不能简单的用“优劣”、“好坏”去衡量。要看这个选择是否给给予你想要的&#xff0c;还要看这个选择的代价是否是你愿意承受并…

如何在华为OD机试中获得满分?Java实现【计算某字符出现次数】一文详解!

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 &#x1f31f;专栏地址: Java华为OD机试真题&#xff08;2022&2023) 文章目录 1. 题目描述2. 输入描述3. 输出描述…

还没搞懂重写和重载吗?这篇文章可以帮助你

文章目录 前言一、向上转型1.概念&#xff1a;2.CODE 二、重写三.重载四.动态和静态绑定总结 前言 首先&#xff0c;会大致介绍一下什么叫做向上转型&#xff0c;方便后续的理解 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、向上转型 1.概念&a…

JQuery实现小项目

博主简介&#xff1a;想进大厂的打工人博主主页&#xff1a;xyk:所属专栏: JavaEE初阶 目录 文章目录 一、JQuery是什么 二、JQuery项目 2.1 猜数字 2.2 表白墙 2.3 聚合搜索 2.4 计算器 一、JQuery是什么 jQuery是一个快速、简洁的JavaScript框架&#xff0c;是继Prototype之…