我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么找到链表的倒数第n个结点

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么找到链表的倒数第n个结点

本篇内容主要讲解“怎么找到链表的倒数第n个结点”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么找到链表的倒数第n个结点”吧!

怎么找到链表的倒数第n个结点

什么意思呢?我们以下面这个链表为例:

怎么找到链表的倒数第n个结点

给定链表的头结点,但并不知道链表的实际长度,要求我们找到链表的倒数第n个结点。

假设n=3,那么要寻找的结点就是元素1:

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

如何利用队列呢?小灰的思路如下:

1.创建一个长度为n的队列,遍历原始链表,让结点逐一进入队列:

怎么找到链表的倒数第n个结点

2.当队列已满时,让队尾元素出队,新结点入队:

怎么找到链表的倒数第n个结点

3.当链表全部结点遍历完毕时,队尾的元素就是倒数第n个结点(因为队列长度是n):

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

————————————

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

首先,我们创建两个指针P1和P2,P1指向链表的头结点,P2指向链表的正数第n个结点(也就是例子中的第3个结点):

怎么找到链表的倒数第n个结点

接下来,我们让指针P1和P2同时循环右移,每次右移一步,直到指针P2移动到链表的末尾:

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

此时,由于P2指向链表的尾结点,且P1和P2的距离是n-1,因此P1所指的结点就是我们要寻找的链表倒数第n个结点:

怎么找到链表的倒数第n个结点

显然,这个方法从头到尾只需要对链表做一次遍历,而且仅仅使用了两个指针,算法的空间复杂度是O(1)。

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

public class NthFromEnd {     public static Node findNthFromEnd(Node head, int n){         Node p1 = head;         Node p2 = head;         //把p2指针移动到正数第n个结点         for(int i=1; i<n; i++){             p2 = p2.next;             if(p2 == null){                 throw new IllegalArgumentException("参数n超出链表长度!");             }         }         //p1和p2一起右移,直到p2指向链表尾结点         while (p2.next != null){             p1 = p1.next;             p2 = p2.next;         }         return p1;     }      //快速创建链表     private static Node buildLinkList(int[] array){         Node head = new Node(array[0]);         Node p = head;         for(int i=1; i<array.length; i++){             p.next = new Node(array[i]);             p = p.next;         }         return head;     }      //链表节点     private static class Node {         int data;         Node next;          Node(int data) {             this.data = data;         }     }      public static void main(String[] args) {         int[] inputs = {5,3,7,2,4,1,9,8};         Node head = buildLinkList(inputs);         Node node = findNthFromEnd(head,3);         System.out.println("链表倒数第3个元素是:" + node.data);     }  }

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

怎么找到链表的倒数第n个结点

到此,相信大家对“怎么找到链表的倒数第n个结点”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么找到链表的倒数第n个结点

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

List怎么删除链表的倒数第N个节点

本篇内容介绍了“List怎么删除链表的倒数第N个节点”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题:删除链表的倒数第N个节点题目给定一个
2023-06-19

C++实现移除链表倒数第N个节点

这篇文章主要讲解了“C++实现移除链表倒数第N个节点”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++实现移除链表倒数第N个节点”吧! Remove Nth Node From End o
2023-06-20

利用Java怎么将链表输出到倒数第k个节点

利用Java怎么将链表输出到倒数第k个节点?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。问题描述输入一个链表,输出该链表中倒数第k个结点。结点定义如下:publ
2023-05-31

编程热搜

目录