码迷,mamicode.com
首页 > 其他好文 > 详细

剑指offer:链表中倒数第k个结点

时间:2020-01-28 12:19:40      阅读:58      评论:0      收藏:0      [点我收藏+]

标签:find   长度   快慢指针   node   nbsp   一个   描述   public   turn   

一、题目描述

  输入一个链表,输出该链表中倒数第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;
    }
}

  

剑指offer:链表中倒数第k个结点

标签:find   长度   快慢指针   node   nbsp   一个   描述   public   turn   

原文地址:https://www.cnblogs.com/blzm742624643/p/12237706.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!