如何利用Java输出链表中倒数第k个结点
作者:WYSCODER 时间:2022-11-29 10:13:28
前言
链表是一种数据结构,和数组同级。比如,Java中我们使用的ArrayList,其实现原理是数组。而LinkedList的实现原理就是链表了。链表在进行循环遍历时效率不高,但是插入和删除时优势明显
本文主要介绍的是输出链表中倒数第k个结点,下面来一起看看详细的介绍吧
问题描述
给你一个单链表,输出倒数第k个结点,如下图链表中,输出倒数第k个结点,比如 k = 2,输出5这个结点。
方法一
方法描述
输出倒数第k个结点就是输出整数第len - k + 1个结点,len为链表的长度。
动画演示
代码如下
/**
* Definition for singly-linked list.
* public class Node {
* int val;
* Node next;
* Node() {}
* Node(int val) { this.val = val; }
* Node(int val, Node next) { this.val = val; this.next = next; }
* }
*/
class Solution {
//计算链表的长度
private int size() {
int count = 0;
for(Node p = head;p != null;p = p.next) {
count++;
}
return count;
}
//返回倒数第k个结点
public Node outputLastIndexNode(int k) {
//链表为空
if (head == null) {
return null;
}
//链表长度
int len = size();
//检测k值
if(k > len || k < 0) {
System.out.println("k值有误!!!");
}
Node p = head;
for(int i = 0; i < len - k; i++) {
p = p.next;
}
return p;
}
方法二
方法描述
1)定义一个q变量指向链表的第一个结点,是q变量往后移动k个结点。
2)定义一个p变量指向链表的第一个结点。
3)p变量和q变量同时循环往后移动一个结点,直到q为null。
动画演示
代码如下
/**
* Definition for singly-linked list.
* public class Node {
* int val;
* Node next;
* Node() {}
* Node(int val) { this.val = val; }
* Node(int val, Node next) { this.val = val; this.next = next; }
* }
*/
class Solution {
//计算链表的长度
private int size() {
int count = 0;
for(Node p = head;p != null;p = p.next) {
count++;
}
return count;
}
//返回倒数第k个结点
public Node outputLastIndexNode(int k) {
//链表为空
if (head == null) {
return null;
}
//链表长度
int len = size();
//检测k值
if(k > len || k < 0) {
System.out.println("k值有误!!!");
}
Node q = head;
//使q往后移动k个结点
while(k-- > 0) {
q = q.next;
}
Node p = head;
while( q != null) {
q = q.next;
p = p.next;
}
return p;
}
来源:https://blog.csdn.net/sheng0113/article/details/121799644
标签:java,链表,结点
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
详解mysql插入数据后返回自增ID的七种方法
2023-07-01 21:32:20
![](https://img.aspxhome.com/file/2023/3/62043_0s.png)
Java servlet、filter、listener、interceptor之间的区别和联系
2023-11-02 15:32:17
Android自定义view利用PathEffect实现动态效果
2023-08-17 09:35:00
![](https://img.aspxhome.com/file/2023/0/139270_0s.gif)
常用的C语言排序算法(两种)
2022-12-28 02:28:37
Java编程用指定字符打印菱形实例
2022-02-23 05:49:09
Spring+Vue整合UEditor富文本实现图片附件上传的方法
2022-09-27 10:36:13
![](https://img.aspxhome.com/file/2023/3/78033_0s.png)
android异步消息机制 源码层面彻底解析(1)
2023-10-02 07:08:52
![](https://img.aspxhome.com/file/2023/8/85958_0s.jpg)
android 修改launcher行数和列数的方法
2021-10-02 14:19:37
![](https://img.aspxhome.com/file/2023/1/139351_0s.png)
详解SpringCloud Ribbon 负载均衡通过服务器名无法连接的神坑
2021-06-01 07:28:41
![](https://img.aspxhome.com/file/2023/7/61237_0s.png)
C# Random类随机函数实例详解
2021-09-12 04:26:42
![](https://img.aspxhome.com/file/2023/2/83282_0s.png)
浅谈Java slf4j日志简单理解
2021-07-07 15:49:15
Java线程安全问题小结_动力节点Java学院整理
2021-09-25 21:01:43
Java KindEditor粘贴图片自动上传到服务器功能实现
2023-08-07 01:42:33
![](https://img.aspxhome.com/file/2023/2/57902_0s.gif)
IDEA java出现无效的源发行版14解决方案
2021-06-25 08:50:33
![](https://img.aspxhome.com/file/2023/2/62172_0s.png)
灵活使用Android中ActionBar和ViewPager切换页面
2022-07-08 17:20:09
![](https://img.aspxhome.com/file/2023/5/137395_0s.gif)
Java与kotlin详细对比
2022-04-13 23:26:47
浅谈@Value和@Bean的执行顺序问题
2023-02-25 18:30:24
C# 匿名方法基础回顾
2023-02-27 13:59:23
![](https://img.aspxhome.com/file/2023/7/116497_0s.png)
c#和java base64不一致的解决方法
2022-11-24 02:18:55
![](https://img.aspxhome.com/file/2023/0/68740_0s.png)
详解Jackson 使用以及性能介绍
2023-02-21 00:08:31
![](https://img.aspxhome.com/file/2023/0/68570_0s.png)