题目
给定链表头结点 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;
}
}
评论区