19. 删除链表的倒数第 N 个结点

简介: 19. 删除链表的倒数第 N 个结点

删除链表的倒数第 N 个结点

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

进阶:你能尝试使用一趟扫描实现吗?


示例 1:


输入:head = [1,2,3,4,5], n = 2

输出:[1,2,3,5]

示例 2:


输入:head = [1], n = 1

输出:[]

示例 3:


输入:head = [1,2], n = 1

输出:[1]


提示:

链表中结点的数目为 sz

1 <= sz <= 30

0 <= Node.val <= 100

1 <= n <= sz

/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
 * @param {ListNode} head
 * @param {number} n
 * @return {ListNode}
 */
 var removeNthFromEnd = function(head, n) {
                let pointFront,pointBack ;
                let flag=0,reArray = new ListNode();
                head.front = null;
                pointFront = pointBack = head;

                let count = 1;
                //  使单链表变成双向链表
                while(pointBack.next!= null){// pointFront始终指向的是前一个节点 pointBack始终指向的是后一个节点
                    pointBack = pointFront.next;
                    pointBack.front = pointFront;
                    pointFront = pointBack;
                    flag = 1;
                 }
                 if(flag==0) return head.next;
                pointFront = pointBack.front;
                // 找到最后一个结点,现在开始往回找
                while(count < n){//小于说明还没有找到
                    pointBack = pointFront;
                    pointFront = pointFront.front;
                    count++;
                     
                }
                if(pointBack.front == null) 
                    return pointBack.next;
                else
                    pointFront.next = pointBack.next;
                return head;
 };
相关文章
|
1月前
|
算法
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
【❤️算法笔记❤️】-每日一刷-19、删除链表的倒数第 N个结点
69 1
|
26天前
|
存储 算法 搜索推荐
链表的中间结点
【10月更文挑战第24天】链表的中间结点是链表操作中的一个重要概念,通过快慢指针法等方法可以高效地找到它。中间结点在数据分割、平衡检测、算法应用等方面都有着重要的意义。在实际编程中,理解和掌握寻找中间结点的方法对于解决链表相关问题具有重要价值。
14 1
|
2月前
链表的中间结点
链表的中间结点
179 57
|
1月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
44 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
1月前
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
(剑指offer)18、删除链表的节点—22、链表中倒数第K个节点—25、合并两个排序的链表—52、两个链表的第一个公共节点(2021.12.07)
49 0
|
1月前
【LeetCode 09】19 删除链表的倒数第 N 个结点
【LeetCode 09】19 删除链表的倒数第 N 个结点
17 0
05_删除链表的倒数第N个节点
05_删除链表的倒数第N个节点
|
3月前
|
算法
LeetCode第19题删除链表的倒数第 N 个结点
该文章介绍了 LeetCode 第 19 题删除链表的倒数第 N 个结点的解法,通过使用快慢双指针,先将快指针移动 n 步,然后快慢指针一起遍历,直到快指针到达链尾,从而找到倒数第 N 个结点的前一个结点进行删除,同时总结了快慢指针可减少链表遍历次数的特点。
LeetCode第19题删除链表的倒数第 N 个结点
|
3月前
|
Python
【Leetcode刷题Python】剑指 Offer 22. 链表中倒数第k个节点
Leetcode题目"剑指 Offer 22. 链表中倒数第k个节点"的Python解决方案,使用双指针法找到并返回链表中倒数第k个节点。
54 5
|
4月前
【数据结构OJ题】链表中倒数第k个结点
牛客题目——链表中倒数第k个结点
38 1
【数据结构OJ题】链表中倒数第k个结点