题解 | #链表中倒数最后k个结点#

链表中倒数最后k个结点

http://www.nowcoder.com/practice/886370fe658f41b498d40fb34ae76ff9

解题思路
直接递归该链表到最底端,然后返回,通过计数器统计是否到了倒数第k个点,最后返回该指针所指向的节点.

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param pHead ListNode类 
     * @param k int整型 
     * @return ListNode类、
     */

    int count=0;//计数器
    ListNode p=new ListNode(10);//指针
    public ListNode FindKthToTail (ListNode pHead, int k) {
        recur(pHead,k,p);//递归函数
        return p.next;//返回结果
    }
    void recur(ListNode list,int k,ListNode p)
    {
        if(list==null)
        {
            return ;//终止条件
        }
        recur(list.next,k,p);//递归体
        count++;//返回过程中进行计数
        if(count==k)//如果满足题目要求就将指针指向这个倒数第k个节点
        {
            p.next=list;
        }
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-03 16:22
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-02 15:39
点赞 评论 收藏
分享
06-08 22:25
门头沟学院 Java
从零开始的转码生活:这hr不会打开手机不分青红皂白给所有人群发这句话,过一会再给所有人再发一遍,这肯定会有重复的,不管,再过一会再发一遍
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务