Leetcode19. 删除链表的倒数第n个结点

news2025/1/16 13:56:40

一、题目描述:

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

  1. 示例 1:
    • 输入:head = [1,2,3,4,5], n = 2
    • 输出:[1,2,3,5]
  2. 示例 2:
    • 输入:head = [1], n = 1
    • 输出:[]
  3. 示例 3:
    • 输入:head = [1,2], n = 1
    • 输出:[1]
  • 提示:
    • 链表中结点的数目为 sz
    • 0 ≤ N o d e . v a l ≤ 100 0 \leq Node.val \leq 100 0Node.val100
    • 1 ≤ n ≤ s z 1 \leq n \leq sz 1nsz

二、解决思路和代码

1. 解决思路:借助两个指针实现一趟扫描完成

  • 分析:链表的长度是 sz ,删除倒数第 n 个节点,那么链表的长度 s z ≥ n sz \geq n szn。怎么找到倒数第 n 个结点呢?

    • 删除倒数第n个节点,前面有sz-n个节点。反之,前面有n个节点,那么后面有sz-n个节点。
      • 第一个指针cur:找到从前面数第n个节点
      • 第二个指针pre:找到从前面数第sz-n个节点。则pre.next就是要删除的节点。
    • 其他情况
      • 有一个节点
      • 有两个节点

2. 代码

 from typing import *
 class ListNode:
     def __init__(self, val=0, next=None):
         self.val = val
         self.next = next
         
 class Solution:
     def removeNthFromEnd(self, head: Optional[ListNode], n: int) -> Optional[ListNode]:
         cur = head
         count = 0
         while cur:
             count+=1
             if count-n < 0: cur = cur.next

             ## 只有一个结点,删除第一个结点(尾结点)
             if count-n==0 and cur.next==None: return head.next  
             if count-n==1:
                 ## 只有两个结点,删除尾结点
                 if cur.next==None:
                     head.next = head.next.next
                     return head
                 else:
                     cur = cur.next
                     pre = head
             if count-n>1:
                 while cur.next:
                     cur = cur.next
                     pre = pre.next  
                 break         
         pre.next = pre.next.next
         return head

 if __name__ == '__main__':
 
     head = [1,2,3,4,5]
     n = 2
     
     lsHead = pre = ListNode(val=-1)
     for i in head:
         cur = ListNode(val=i)
         pre.next = cur
         pre = cur
 
     res = Solution().removeNthFromEnd(lsHead.next, n)
     cur = res
     while cur:
         print(cur.val)
         cur = cur.next
 ```

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/378961.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android开发八股文,Android也有自己的八股文了

前言别的行业都有自己的八股文&#xff0c;凭什么Android没有。2023春招即将来临&#xff0c;很多同学会问 Android开发的面试题有必要背吗&#xff1f;我的回答是&#xff1a;很有必要。你可以讨厌这种模式&#xff0c;但你一定要去背&#xff0c;因为不背你就进不了大厂。国内…

SSL/TLS协议信息泄露漏洞(CVE-2016-2183)调查解决

目录结构前言测试回馈漏洞介绍漏洞解决参考文献前言 产品测试阶段出现“SSL/TLS协议信息泄露漏洞&#xff08;CVE-2016-2183&#xff09;”&#xff0c;解决过程记录如下 测试回馈 建议&#xff1a;避免使用IDEA、DES和3DES算法 1、OpenSSL Security Advisory [22 Sep 2016] …

P02 滴水逆向1月4号公开课

公开课进制转换汇编如何工作的逻辑运算二进制逻辑运算|| 运算 和 | 运算&& 运算 和 & 运算^(异或) 运算! (非)运算左移二进制逻辑运算应用加法运算运算与电脑硬件进行加密寄存器内存寻址范围使用内存寻址公式堆栈变形的艺术进制转换 二进制十六进制如何转换的 汇…

k8s学习之路 | Day17 k8s 工作负载

文章目录工作负载的定义工作负载资源分类工作负载的定义 官方参考链接&#xff1a;https://kubernetes.io/docs/concepts/workloads/ A workload is an application running on Kubernetes. Whether your workload is a single component or several that work together, on K…

已解决ERROR: Failed building wheel for opencv-python-headless

已解决ERROR: Failed building wheel for opencv-python-headless Failed to build opencv-python-headless ERROR: Could not build wheels for opencv-python-headless, which is required to install pyproject.toml-based projects报错信息亲测有效 文章目录报错问题报错翻…

多任务学习概述

文章目录前言1 文章信息2 背景、目的、结论2.1 背景2.1.1 多任务的类型分类2.1.1.1 相关任务的分类2.1.1.2 将输入变输出的逆多任务学习2.1.1.3 对抗性多任务学习2.1.1.4 辅助任务提供注意力特征的多任务学习2.1.1.5 附加预测性辅助任务的多任务学习3 内容与讨论3.1 多任务学习…

HTML+ CSS 笔记

CSS1. 外边距合并 margin2. 浮动和清除浮动3. CSS 属性书写顺序(重点)4. 页面布局分析5. 定位定位模式子绝父相&#xff1a;z-index定位的拓展6. 元素的显示与隐藏7. 精灵图 sprites8. 字体图标 iconfont9. 居中10. 文字溢出处理情况11.HTML5 和CSS3 新增标签12.品优购1. 项目规…

多数据库管理工具哪家强?ChatGPT点评,第一位并不是Navicat

SQL逐渐成为职场必备的编程语言&#xff0c;相信大家都不陌生。SQL是一种结构化查询语言&#xff0c;是用于数据库之间通信的编程语言。每个数据库都有着自己独特的访问规则&#xff0c;但大体上是遵循SQL标准。 因此&#xff0c;辗转于不同的数据库之间&#xff0c;开发者或D…

Codeforces Round #852 (Div. 2) D. Moscow Gorillas

传送门 题意&#xff1a; 给你两个长度为n的排列p&#xff0c;q&#xff0c;同时定义mex表示为在mex中&#xff0c;缺少的最小正整数&#xff1a;如 mex[1&#xff0c;3]2&#xff0c;mex[1,2,3]4。 问你有多少个l,r使mex([])mex([])。 思路 &#xff1a; 可以从mex1,2,3,4,..n…

Word 行中公式与文字对不齐的解决方案

Word 行中公式与文字对不齐的解决方案问题-公式与文字不对齐解决方案简述版(亲测)解决方案详细版(亲测)参考方案问题-公式与文字不对齐 由于复制或其它误操作&#xff0c;可能会出现Word一行中公式与文字并不对齐的问题&#xff0c;有的公式会偏上或偏下&#xff0c;如下图所示…

【Linux内核】内核编程概述

1.GNU GNU计划和自由软件基金会&#xff08;FSF&#xff09;是由Richard M.Stallman于1984年创办的&#xff0c;GNU是“GNU’s Not UNIX”的缩写。到20世纪90年代初&#xff0c;GNU项目已经开发出许多高质量的免费软件&#xff0c;其中包括emacs编辑系统、bash shell程序、gcc…

PIGOSS BSM 信创运维之国产数据库监控

随着信创的推进&#xff0c;为国产数据库厂商提供了发展沃土&#xff0c;国产厂商扮演者越来越重要的角色。国产数据库以达梦、人大金仓、南大通用、高斯数据库GaussDB、万里开源为代表&#xff0c;而新兴厂商则利用分布式进行换道超车&#xff0c;以PingCAP、巨杉数据库、星环…

JAVA对象

目录 1.组成 1.1.概述 1.2.对象头 1.3.实例数据 1.4.对齐填充字节 2.实例化流程 1.组成 1.1.概述 JAVA对象由三部分组成&#xff1a; 对象头实例数据对齐填充字节1.2.对象头 对象头里面包含3部分主要内容&#xff1a; markwordklass数组长度&#xff08;只有数组对象…

StreamYOLO 代码阅读记录

目录 一、安装配置环境 二、运行 train.py文件遇到的问题 问题一 问题二 问题三 问题四 问题五 问题六 问题七 问题八 二、debug记录 1、 args 2、optimizer 3、ckpt 4、self.seq_dirs 5、self._classes 6、im_ann 7、annotations 8、obj 9、self.train_loade…

Qt——拖拽

Qt的拖拽可以按字面意思分为拖和拽两部分。一般来说我们常见的拖拽分别由两个程序合作完成。例如我们经常把桌面的文件拖拽进其他目录&#xff1a; ​ 编辑拖拽方可以发起多个拖拽类型&#xff08;复制、链接、移动等&#xff09;&#xff0c;接收方可以选择接受其中某个类型或…

《分布式技术原理与算法解析》学习笔记Day25

负载均衡 负载均衡是分布式可靠性中非常关键的一个问题&#xff0c;它在一定程度上反映了分布式系统对业务处理的能力。 什么是负载均衡&#xff1f; 负载均衡可以分为两种&#xff1a; 请求负载均衡&#xff0c;即将用户的请求均衡的分发到不同的服务器进行处理。数据负载…

扬帆优配|弹性增强 双向波动明显 人民币汇率走势将回归基本面

离岸人民币对美元汇率走势图 美联储加息预期起波澜&#xff0c;人民币汇率再临“7”关口。 到2月27日16时30分&#xff0c;在岸人民币对美元汇率收盘报6.9645&#xff1b;离岸人民币对美元汇率盘中最低触及6.9896&#xff0c;险些失守6.99关口。 人民币汇率走贬的一起&#x…

Odoo | Webserivce | 5分钟学会【JSONRPC】接口开发 - 换USERID(进阶)

文章目录JSONRPC - 换取USERID简述换取USERID1. 代码示例2. 换取结果JSONRPC - 换取USERID 简述 从Odoo JSONRPC 接口入门篇&#xff0c;可以发现我们直接传入了USERID&#xff0c;这只是为了方便快速测试。 其实按照常规流程&#xff0c;应该通过【用户名USERNAME】和【用户…

【LeetCode】No.237. 删除链表中的节点 – Java Version

题目链接&#xff1a;https://leetcode.cn/problems/delete-node-in-a-linked-list/ 1. 题目介绍&#xff08;237. 删除链表中的节点&#xff09; 有一个单链表的 head&#xff0c;我们想删除它其中的一个节点 node。 给你一个需要删除的节点 node 。你将 无法访问 第一个节点…

consul注册中心服务All service checks failing及解决

文章目录consul注册中心服务All service checks failing问题一&#xff1a;能注册&#xff0c;有报错&#xff0c;中间件不可用问题二&#xff1a;能注册&#xff0c;没报错&#xff0c;通不过检查问题三&#xff1a;同一个服务&#xff0c;注册了很多次consul注册中心服务All …