侧边栏壁纸
博主头像
GabrielxD

列車は必ず次の駅へ。では舞台は?私たちは?

  • 累计撰写 471 篇文章
  • 累计创建 108 个标签
  • 累计收到 9 条评论

目 录CONTENT

文章目录

【链表, 模拟】链表组件

GabrielxD
2022-10-12 / 0 评论 / 0 点赞 / 20 阅读 / 475 字 / 正在检测是否收录...

题目

817. 链表组件


给定链表头结点 head,该链表上的每个结点都有一个 唯一的整型值 。同时给定列表 nums,该列表是上述链表中整型值的一个子集。

返回列表 nums 中组件的个数,这里对组件的定义为:链表中一段最长连续结点的值(该值必须在列表 nums 中)构成的集合。

示例 1:

输入: head = [0,1,2,3], nums = [0,1,3]
输出: 2
解释: 链表中,0 和 1 是相连接的,且 nums 中不包含 2,所以 [0, 1] 是 nums 的一个组件,同理 [3] 也是一个组件,故返回 2。

示例 2:

输入: head = [0,1,2,3,4], nums = [0,3,1,4]
输出: 2
解释: 链表中,0 和 1 是相连接的,3 和 4 是相连接的,所以 [0, 1] 和 [3, 4] 是两个组件,故返回 2。

提示:

  • 链表中节点数为n
  • 1 <= n <= 10^4
  • 0 <= Node.val < n
  • Node.val 中所有值 不同
  • 1 <= nums.length <= n
  • 0 <= nums[i] < n
  • nums 中所有值 不同

解题

方法一:模拟

思路

维护一个哈希表(has)(可用布尔数组代替)方便查询数字是否出现在 nums 中。

然后枚举链表中的每个节点,如果遇到在 nums 中存在的数就向后枚举直到遇到不存在于 nums 中的数或者枚举到了链表末尾,此时找出了一个完整的组件,计数(cnt)增加,接着向后找直到找到所有组件返回计数。

代码

class Solution {
    public int numComponents(ListNode head, int[] nums) {
        boolean[] has = new boolean[10001];
        for (int num : nums) has[num] = true;
        int cnt = 0;
        while (head != null) {
            if (has[head.val]) {
                while (head != null && has[head.val]) head = head.next;
                ++cnt;
            } else head = head.next;
        }
        return cnt;
    }
}
0

评论区