首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何删除链表中的节点?

删除链表中的节点可以通过修改指针的方式来实现。具体步骤如下:

  1. 首先,判断要删除的节点是否是头节点。如果是头节点,直接将头节点指向下一个节点即可完成删除操作。
  2. 如果要删除的节点不是头节点,需要先找到要删除节点的前一个节点。遍历链表,直到找到前一个节点为止。
  3. 将前一个节点的指针指向要删除节点的下一个节点,跳过要删除的节点。
  4. 释放要删除的节点的内存空间,完成删除操作。

删除链表中的节点可以使用以下代码实现:

代码语言:txt
复制
class ListNode:
    def __init__(self, val=0, next=None):
        self.val = val
        self.next = next

def deleteNode(head, val):
    # 判断头节点是否为要删除的节点
    if head.val == val:
        return head.next
    
    # 遍历链表,找到要删除节点的前一个节点
    prev = head
    curr = head.next
    while curr:
        if curr.val == val:
            prev.next = curr.next
            curr.next = None
            break
        prev = curr
        curr = curr.next
    
    return head

这段代码中,我们定义了一个链表节点类 ListNode,包含值 val 和指向下一个节点的指针 nextdeleteNode 函数接受链表的头节点和要删除的节点的值作为参数,返回删除节点后的链表头节点。

这是一个简单的链表节点删除操作的实现,适用于单链表。在实际应用中,可能还需要考虑其他情况,如双向链表、循环链表等。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

删除链表节点

题目描述 难度级别:简单 请编写一个函数,使其可以删除某个链表给定(非末尾)节点。传入函数唯一参数为 要被删除节点 。...示例 2: 输入:head = [4,5,1,9], node = 1 输出:[4,5,9] 解释:给定你链表中值为 1 第三个节点,那么在调用了你函数之后,该链表应变为 4 -> 5 -> 9....提示: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...解题思路 题目中待传递给当前函数实参node,它是链表某一个待删除节点,然后从链表删除这个节点。...这里因为待传入实参没有完整链表,所以无法获取到之前节点,所以无法修改前一个节点next指向。这时需要是将要删除节点值替换为它下一个节点值,之后要删除这个节点next指向为下下一项。

2.4K00
  • 237 删除链表节点

    01 题目信息 题目地址: https://leetcode-cn.com/problems/delete-node-in-a-linked-list/ 请编写一个函数,使其可以删除某个链表给定(非末尾...传入函数唯一参数为 要被删除节点 。 现有一个链表 -- head = [4,5,1,9],它可以表示为: ?...提示: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...x) { val = x; } } 现在它传一条链表一个节点删除这个节点。...这样就不用改变4节点指向,只是把它指向这个对象值与next都改掉,那么4还是指向0x001只不过是1了,而这个指向又是0x004就是9,链表也就变成了4--->1--->9完成删除5操作 public

    1.3K10

    删除链表重复节点.

    前言 在一个排序链表,存在重复节点如何删除链表重复节点并返回删除链表头指针?例如:1->2->3->3->4->4->5,处理后为: 1->2->5。...本文将分享这个问题解决思路与实现代码,欢迎各位感兴趣开发者阅读本文。 常规思路 根据题意,我们可以知道链表元素是排好序。如果节点重复的话,当前节点一定与下一个节点相同。...其次,我们需要创建两个指针: 一个指向当前不重复节点,我们将它命名为pre 一个为搜索指针,用于搜索链表与当前节点不重复节点,我们将它命名为last 随后,我们为 pre 与 last 进行初始赋值...20220226224625702 实现代码 接下来,我们将上述思路转换为代码,如下所示: /** * 删除链表重复节点 * @param pHead 链表节点 */ deleteDuplicatesNode...* * 删除链表重复节点(递归解法) * @param pHead 链表节点 */ deleteDuplicatesNodeForRecursion(pHead: ListNode

    2.8K40

    2 删除链表节点

    复习链表插入 链表一个节点是由数据域和指针域构成,指针域地址值为下个元素地址。那么我们需要插入或者删除一个元素怎么处理呢? ? 先查看原始链表结构,准备将结点x插入链表。 ?...复习链表删除 上面简单介绍了带头结点链表,在删除处理时候同样适用,所以我们以后就直接采用带头结点链表讲解。下面直接看看删除节点图。 ?...1 Leetcode237 删除链表节点 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。 先思考一分钟哟! 效果更好哈!...目标还是删除5,最后结果为[4,1,9]。我们把需要删除5结点后面节点1赋值给它,如下图8. ?

    1.3K20

    Swift 删除链表节点 - LeetCode

    LeetCode 题目: 删除链表节点 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...现有一个链表 -- head = 4,5,1,9,它可以表示为: 4 -> 5 -> 1 -> 9 示例1: 输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释...: 给定你链表中值为 5 第二个节点,那么在调用了你函数之后,该链表应变为 4 -> 1 -> 9....示例2: 输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 第三个节点,那么在调用了你函数之后,该链表应变为 4 -> 5 -> 9...说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。

    1.3K40

    动画:删除链表节点

    大家好,我是帅吴,欢迎来到 图解剑指 Offer 结构化专栏,在这个专栏里我将和大家一起学习如何用结构化思维来思考、解题、写代码,希望能帮助你即使在面试时候紧张也能做对。...说明: 题目保证链表节点值互不相同 若使用 C 或 C++ 语言,你不需要 free 或 delete 被删除节点 二、题目解析 我们依旧用 四步分析法 进行结构化分析。...删除链表节点副本.004 定位到目标节点后,需要修改这个节点,题目的要求是删除,对于链表每个节点来说,它都有前驱和后继两个节点,那么删除操作就很简单了:设节点 cur 前驱节点为 pre ,后继节点为...删除链表节点.005 2、规律 链表删除操作一般都是使用双指针。 3、匹配 双指针。 4、边界 删除节点是头节点 三、动画描述 四、图片描述 面试题18. 删除链表节点.002 面试题18....删除链表节点.003 面试题18. 删除链表节点.004 面试题18. 删除链表节点.005 面试题18. 删除链表节点.006 面试题18. 删除链表节点.007 面试题18.

    1.2K40

    Leetcode No.237 删除链表节点

    一、题目描述 请编写一个函数,使其可以删除某个链表给定(非末尾)节点。传入函数唯一参数为 要被删除节点 。...示例 2: 输入:head = [4,5,1,9], node = 1 输出:[4,5,9] 解释:给定你链表中值为 1 第三个节点,那么在调用了你函数之后,该链表应变为 4 -> 5 ->...二、解题思路 从链表删除一个节点 node 最常见方法是修改之前节点 next 指针,使其指向之后节点。...我们无法访问我们想要删除节点 之前 节点,因此我们始终不能修改该节点 next 指针。 换个思路,我们可以将想要删除节点值替换为它后面节点值,然后删除它之后节点。...因为我们知道要删除节点不是列表末尾,所以我们可以保证这种方法是可行

    41940

    删除链表节点

    题目信息 请编写一个函数,使其可以删除某个链表给定(非末尾)节点,你将只被给定要求被删除节点。...示例 1: 输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 第二个节点,调用函数后,该链表应变为 4 -> 1 -> 9....示例 2: 输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 第三个节点,调用函数后,该链表应变为 4 -> 5 -> 9....说明: 链表至少包含两个节点链表中所有节点值都是唯一。 给定节点为非末尾节点并且一定是链表一个有效节点。 不要从你函数返回任何结果。...解题 只给定了要删除节点,无法得知上一个next指针 直接交换要删节点值与其next存val 删除其next节点即可 /** * Definition for singly-linked

    40720

    算法篇:链表删除链表重复节点

    算法: 核心点在于如何找到重复节点,有序链表的话,只要下一个节点与当前节点数值一样就是重复节点,直接将当前节点指向下一个节点下一个节点即可。 本算法需要注意哨兵节点小技巧。...题目1:删除排序链表重复元素 https://leetcode-cn.com/problems/remove-duplicates-from-sorted-list/submissions/ ?...题目2: 删除排序链表重复元素 ?...代码实现 // 算法:与题目1不同之处在于,本题目是删除所有重复节点, // 也就是说不单单要找到重复节点位置, // 还需要将第一个重复节点前一个节点记录下来,这里叫做pre // 然后通过pre.Next...去指向重复节点后面哪一个不重复节点,来完成删除

    71010
    领券