LeetCode 3217.从链表中移除在数组中存在的节点:哈希表(一次遍历)

【LetMeFly】3217.从链表中移除在数组中存在的节点:哈希表(一次遍历)

力扣题目链接:https://leetcode.cn/problems/delete-nodes-from-linked-list-present-in-array/

给你一个整数数组 nums 和一个链表的头节点 head。从链表中移除 所有存在于 nums 中的节点后,返回修改后的链表的头节点。

示例 1:
输入: nums = 1,2,3, head = 1,2,3,4,5

输出: 4,5

解释:

移除数值为 1, 2 和 3 的节点。

示例 2:
输入: nums = 1, head = 1,2,1,2,1,2

输出: 2,2,2

解释:

移除数值为 1 的节点。

示例 3:
输入: nums = 5, head = 1,2,3,4

输出: 1,2,3,4

解释:

链表中不存在值为 5 的节点。

提示:

  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 105
  • nums 中的所有元素都是唯一的。
  • 链表中的节点数在 [1, 105] 的范围内。
  • 1 <= Node.val <= 105
  • 输入保证链表中至少有一个值没有在 nums 中出现过。

解题方法:哈希表

使用哈希表记录 n u m s nums nums中都出现了哪些元素。

为了方便可以在链表第一个节点前设置一个一定不会被删除的没有实际值的"表头",并使用两个变量 l a s t last last和 n o w now now记录上一个遍历到的节点和当前节点。

在 n o w now now不为空时,若 n o w now now在 n u m s nums nums中出现过,则扔掉 n o w now now(更新 l a s t last last的 n e x t next next为 n o w now now的 n e x t next next、 n o w now now后移);否则不删 n o w now now( l a s t last last和 n o w now now都指向下一个节点)。

  • 时间复杂度 O ( l e n ( n u m s ) + l e n ( l i s t ) ) O(len(nums) + len(list)) O(len(nums)+len(list))
  • 空间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))

AC代码

C++
cpp 复制代码
/*
 * @LastEditTime: 2025-11-01 21:54:45
 */

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* modifiedList(vector<int>& nums, ListNode* now) {
        unordered_set<int> se(nums.begin(), nums.end());
        ListNode* head = new ListNode(0, now);  // 不可以:ListNode* head(0, now);
        ListNode* last = head;
        while (now) {
            if (se.count(now->val)) {
                now = now->next;
                last->next = now;
            } else {
                last = now;
                now = now->next;
            }
        }
        return head->next;
    }
};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
如竟没有火炬7 小时前
寻找峰值——二分
java·开发语言·数据结构·python·算法·散列表
z2005093013 小时前
今日算法(回溯全排列)
c++·算法·leetcode
Lucky_ldy13 小时前
数据结构从入门到精通:链表
数据结构·链表
love_muming14 小时前
从 ArrayList 到 LinkedList:Java 集合中数组与链表的深度对比
java·数据结构·链表
小欣加油14 小时前
leetcode3633 最早完成陆地和水上游乐设施的时间I
数据结构·c++·算法·leetcode
memcpy014 小时前
LeetCode 2657. 找到两个数组的前缀公共数组【集合,位运算】中等
算法·leetcode·职场和发展
踩坑记录14 小时前
leetcode 912 排序数组 堆排序
leetcode
8Qi814 小时前
LeetCode 236. 二叉树的最近公共祖先(LCA)
算法·leetcode·二叉树·递归·lca·后序遍历
兰令水14 小时前
leecodecode【二叉树排序+最近公共祖先】【2026.6.2打卡-java版本】
java·数据结构·算法·leetcode
人道领域14 小时前
【LeetCode刷题日记】77&&216.回溯算法剪枝优化在组合问题中的应用
java·算法·leetcode