牛客题解-NC69链表中倒数第k个节点

题目

输入一个链表,输出该链表中倒数第k个结点。

如果该链表长度小于k,请返回空。

示例1

输入:

1
{1,2,3,4,5},1 

输出:

1
{5}

思路

分析

首先让一个指针first先走k步。

此时再引出一个res指针从head节点开始。

first 和res 指针同时前进。

当first走到尾部时,此时res为倒数第k个节点。

实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import java.util.*;

/*
* public class ListNode {
* int val;
* ListNode next = null;
* public ListNode(int val) {
* this.val = val;
* }
* }
*/

public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param pHead ListNode类
* @param k int整型
* @return ListNode类
*/
public ListNode FindKthToTail (ListNode pHead, int k) {
// write code here
ListNode first = pHead;
for(int i = 0; i<k; i++){
if(first==null) return null;
first = first.next;
}
ListNode res = pHead;
while(first != null){
res = res.next;
first = first.next;
}
return res;
}
}