LeetCode 0203.移除链表元素【Go】

简介: LeetCode 0203.移除链表元素【Go】

移除链表元素

LeetCode203. 移除链表元素

题目描述

给你一个链表的头节点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的指针指向下下一个节点。

注意

  • 若要移除头节点,操作与其他节点不一样,因为移除节点是通过要移除的元素的前一个节点来移除节点,而头节点前没有节点,所以需要单独写一个移除操作。为了使头节点的移除操作与其他节点保持一致,我们可以在头节点前再添加一个结点,该节点数据域为空,指针域指向头节点。
  • 链表有三种:单链表(数据域+指针域)、循环链表(数据域+指针域)、双链表(指针域+数据域+指针域)
  • 为了防止头节点为空,产生编译错误,所以应在循坏判断条件中判断当前节点的下一个节点是否非空
  • 最后返回的是第一个存储元素的节点,即return dummyHead.Next

代码

Go

/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func removeElements(head *ListNode, val int) *ListNode {
  dummyHead := new(ListNode)
  dummyHead.Next = head
  for p := dummyHead; p != nil && p.Next != nil; {
    if p.Next.Val == val {
      p.Next = p.Next.Next
    } else {
      p = p.Next
    }
  }
  return dummyHead.Next
}

Link

GitHub

目录
相关文章
|
3月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
42 1
|
3月前
Leetcode第21题(合并两个有序链表)
这篇文章介绍了如何使用非递归和递归方法解决LeetCode第21题,即合并两个有序链表的问题。
56 0
Leetcode第21题(合并两个有序链表)
|
3月前
【LeetCode 27】347.前k个高频元素
【LeetCode 27】347.前k个高频元素
43 0
|
1月前
|
Go 索引
go语言修改元素
go语言修改元素
35 6
|
3月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
32 0
LeetCode第二十四题(两两交换链表中的节点)
|
3月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
49 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
3月前
|
索引
力扣(LeetCode)数据结构练习题(3)------链表
力扣(LeetCode)数据结构练习题(3)------链表
108 0
|
16天前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
60 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
42 7
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。