剑指offer:链表中倒数第k个结点
一、题目描述
输入一个链表,输出该链表中倒数第k个结点。
二、思路
思路一:
设置两个指针,一个快指针,一个慢指针。
慢指针在第一个节点,快指针先前进k个结点。然后快慢指针一起前进,当快指针到达终点时,慢指针所指结点为倒数第k个结点。
思路二:
先遍历一遍链表,得出链表长度count。然后从头开始前进count-k次,可得倒数第k个结点。
三、代码
/* public class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; } }*/ //思路二 public class Solution { public ListNode FindKthToTail(ListNode head,int k) { if(null==head){ return null; } int count = 0; ListNode node = head; while(node!=null){ count++; node = node.next; } if(count<k){ return null; } ListNode res = head; for(int i=0;i<count-k;i++){ res = res.next; } return res; } }