题目
给你一个链表的头节点 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
输出:[]
提示:
列表中的节点数目在范围 [0, 104] 内
1 <= Node.val <= 50
0 <= val <= 50
解题
编程语言为GO
方法一:
遍历,遍历链接中每个节点,当下一个节点的值等于目标值的时候则指向下下一个节点,实现删除功能
时间复杂度: O(n)
func removeElements(head *ListNode, val int) *ListNode {ln := &ListNode{Next: head}tmp := lnfor tmp.Next != nil {if tmp.Next.Val == val {tmp.Next = tmp.Next.Next} else {tmp = tmp.Next}}return ln.Next
}