当前位置: 首页 > article >正文

leetcode链表(一)-移除链表元素

题目

t. - 力扣(LeetCode)

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。

例1

输入:head = [1,2,6,3,4,5,6], val = 6
输出:[1,2,3,4,5]


示例 2:

输入:head = [], val = 1
输出:[]


示例 3:

输入:head = [7,7,7,7], val = 7
输出:[]

思路

当需要删除的节点是头节点时,需要单独考虑,这时候设置一个虚拟的头节点,将虚拟的头节点指向真实的头节点,将头节点看作普通节点做同样的操作即可,但最后返回的时候一定要返回虚拟头节点的next。

代码

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def removeElements(self, head: Optional[ListNode], val: int) -> Optional[ListNode]:
        if not head:
            return
        phead,cur = ListNode(),ListNode()
        phead.next = head
        cur= phead
        while cur.next:
            if cur.next.val == val:
                cur.next = cur.next.next
            else:
                cur = cur.next
        return phead.next


http://www.kler.cn/news/342891.html

相关文章:

  • html中<div>标签设置宽度和高度都有哪些方法
  • <Project-8.1 pdf2tx-MM> Python Flask 用浏览器翻译PDF内容 2个翻译引擎 繁简中文结果 从P8更改
  • 【SQL】Windows MySQL 服务查询启动停止自启动(保姆级)
  • Leetcode 数组中第 k 大的元素
  • 「自动化测试」Selenium 的使用
  • C++设计模式——代理模式
  • 论文阅读:Split-Aperture 2-in-1 Computational Cameras (二)
  • js中获取、改变、添加、删除元素的方法
  • MyBatis 用法详解
  • 生成对抗网络(GAN,Generative Adversarial Network)
  • 鸿蒙开发(NEXT/API 12)【安全单元访问开发】网络篇
  • 股市入门常见术语介绍
  • C#中ref关键字和out关键字
  • 微服务es+Kibana解析部署使用全流程
  • 千兆超薄lan transformer H82412S应用主板英特尔光仟网卡
  • 【Linux】来查看当前系统的架构
  • 【目标检测】木制地板缺陷破损数据集338张6类VOC+YOLO格式
  • 【系统架构设计师】案例专题四:嵌入式系统考点梳理
  • 网络嗅探:网络安全中的关键概念
  • 传知代码-自动车牌识别检测系统(论文复现)