LeetCode - 删除链表的倒数第N个节点
2024-09-05 18:32:41
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。
示例:
给定一个链表: 1->2->3->4->5, 和 n = 2.
当删除了倒数第二个节点后,链表变为 1->2->3->5.
说明:
给定的 n 保证是有效的。
进阶:
你能尝试使用一趟扫描实现吗?
方法一,使用数组辅助
class ListNode:
def __init__(self, x):
self.val = x
self.next = None
class Solution:
def removeNthFromEnd(self, head: ListNode, n: int) -> ListNode:
a = []
while head:
a.append(head)
head = head.next
if n == len(a):
new = a[0].next
a[0].next = None
return new
if n == 1:
a[-2].next = None
return a[0]
a[-n-1].next = a[-n+1]
return a[0]
方法二,使用快慢指针
双指针 p 和 q 的话,当 q 指向末尾的 NULL,p 与 q 之间相隔的元素个数为 n 时,那么删除掉 p 的下一个指针就完成了要求。
设置虚拟节点 dummyHead 指向 head
设定双指针 p 和 q,初始都指向虚拟节点 dummyHead
移动 q,直到 p 与 q 之间相隔的元素个数为 n
同时移动 p 与 q,直到 q 指向的为 NULL
将 p 的下一个节点指向下下个节点
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def removeNthFromEnd(self, head: ListNode, n: int) -> ListNode:
dummyHead = ListNode(0)
dummyHead.next = head
p = dummyHead
q = dummyHead
for i in range(n+1):
q = q.next
while(q):
p = p.next
q = q.next
p.next = p.next.next
return dummyHead.next
最新文章
- python学习之路-day7
- java14-4 Pattern和Matcher类的使用
- MySQL: InnoDB 还是 MyISAM?
- Careercup - Google面试题 - 5727310284062720
- mysql-gdb--oracle
- Excel导入数据库(三)——SqlBulkCopy
- 为什么要web语义化
- System.Text.RegularExpressions.Regex
- java URL和URLConnection
- python识别验证码——PIL,pytesser,pytesseract的安装
- Java集合:HashMap底层实现和原理(源码解析)
- MySQL Server8.0版本时出现Client does not support authentication protocol requested by server
- 每天一条linux命令
- Tr A HDU1575
- Oracle的FIXED_DATE参数
- Xcode10 libstdc++.6.0.9.tbd移除引起的错误
- swift开发之 -- 自动轮播图(UIScrollView+UIPageControl+Timer)
- 不同复制模式下,如何忽略某些binlog事件
- mp4文件数据格式解析
- Pku3673
热门文章
- LeetCode.927-独特邮箱地址(Unique Email Addresses)
- QA Issue: PN: startUp is upper case, this can result in unexpected behavior. [uppercase-pn]
- CVPR2019 论文解读| BASNet:关注边界的显著性目标检测
- http状态码 超详细
- Django 调用支付宝接口
- spring boot-7.日志系统
- 【转贴】Linux查看物理CPU个数、核数、逻辑CPU个数
- python——列表方法
- 基于Caffe训练AlexNet模型
- layer.prompt绑定确认键