剑指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;
    }
}

  

posted @ 2020-01-28 12:01  DXYE  阅读(158)  评论(0编辑  收藏  举报