《剑指offer》——链表中倒数第k个结点(Java)

题目描述

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

    }
}

思路:

链表,我们不知道长度,所以无法直接输出倒数第k个数。

(我下面说的位置,都是指针指向的位置。)

解法①
我们先遍历一边链表,获取链表长度 L 之后,得出倒数第k个数,是正数第 (L - K)个数。
然后我们再遍历到第 (L-K)个数输出就行了。

解法②
我们创建两个指针,一个快指针,一个慢指针。
快指针先走,走到第 k 个位置时候,慢指针也开始走。(此时快指针和慢指针之间距离一直是7)
当快指针走到最后一个点时,此时 快指针的位置就是 倒数第 k 个数。
因为,快慢指针之间的距离是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)
            return null;
        ListNode fast = head;
        while (fast != null && k-- > 0)
            fast = fast.next;
        if (k > 0)
            return null;
        ListNode low = head;
        while (fast != null){
            fast = fast.next;
            low = low.next;
        }
        return low;
    }
}
发布了83 篇原创文章 · 获赞 22 · 访问量 2221

猜你喜欢

转载自blog.csdn.net/love_MyLY/article/details/103482529