题目:输入一个链表,输出该链表中倒数第k 个结点.为了符合大多数人的习惯,本题从1 开始计数,即链表的尾结点是倒数第1 个结点.例如一个链表有6 个结点,从头结点开始它们的值依次是1 、2、3、4、5 、6。这个个链表的倒数第3 个结点是值为4 的结点.
解题思路:
为了实现只遍历链表一次就能找到倒数第k 个结点,我们可以定义两
个指针。第一个指针从链表的头指针开始遍历向前走k-1步,第二个指针保持不动;从第k 步开始,第二个指针也开始从链表的头指针开始遍历。由于两个指针的距离保持在k-1 , 当第一个(走在前面的)指针到达链表的尾结点时,第二个指针(走在后面的)指针正好是倒数第k 个结点。
package com.www.OfferToSword;
public class Solution15 {
public static class ListNode {
int value;
ListNode next;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
ListNode head = new ListNode();
head.value = 1;
head.next = new ListNode();
head.next.value = 2;
head.next.next = new ListNode();
head.next.next.value = 3;
head.next.next.next = new ListNode();
head.next.next.next.value = 4;
head.next.next.next.next = new ListNode();
head.next.next.next.next.value = 5;
head.next.next.next.next.next = new ListNode();
head.next.next.next.next.next.value = 6;
head.next.next.next.next.next.next = new ListNode();
head.next.next.next.next.next.next.value = 7;
head.next.next.next.next.next.next.next = new ListNode();
head.next.next.next.next.next.next.next.value = 8;
head.next.next.next.next.next.next.next.next = new ListNode();
head.next.next.next.next.next.next.next.next.value = 9;
System.out.println(findTheK(head, 1)); // 倒数第一个
System.out.println(findTheK(head, 5)); // 中间的一个
System.out.println(findTheK(head, 9)); // 倒数最后一个就是顺数第一个
System.out.println();
System.out.println(findTheK(head, 10));
}
public static int findTheK(ListNode head, int k) {
ListNode list = head;
for (int i = 1; i < k; i++) {
if (list.next != null) {
list = list.next;
} else {
throw new RuntimeException("the length id less than k");
}
}
while (list.next != null) {
list = list.next;
head = head.next;
}
return head.value;
}
}