链表-删除倒数第n个节点

代码随想录-刷题笔记

19. 删除链表的倒数第 N 个结点 - 力扣(LeetCode)

内容:

本题思路比较直接,也没太多好说的, 既然是倒数第n个节点, 那么设置一个

fast 领先 slow n个节点, 当fast到达末尾节点的时候, slow自然而然就是目标节点.

代码:

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode dummy = new ListNode();
        dummy.next = head;
        ListNode fast = dummy;
        ListNode slow = dummy;
        for(int i = n ; i > 0 ; i--) {
            fast = fast.next;
        }
        while(fast.next != null) {
            fast = fast.next;
            slow = slow.next;
        }
        if(slow.next != null) {
            slow.next = slow.next.next;
        }

        return dummy.next;
    }
}

总结:

这道题就是思维发散一点,很简单,虽然我自己没想出来就是了....

你可能感兴趣的:(链表,数据结构)