面试题15:链表中倒数第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(head == null || k <= 0)
            return null;
        
        ListNode pre = head;
        ListNode last = head;
        
        for(int i = 0;i < k;i++){
            if(pre != null)
               pre = pre.next; 
            else
                return null;
        }
        
        while(pre != null){
            pre = pre.next;
            last = last.next;
        }
        
        return last;
    }
}

主要思路

1、设置一前一后两个指针 相隔k步 当前面的指针到达链表尾部时 后面的指针就是要找的倒数第k个结点
2、注意边界条件(头指针为空;k <= 0;k大于链表长度)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容