Skip to content

LeetCode 916 LintCode 1726 Word Subsets

Published: at 06:23 AM

Table of contents

Open Table of contents

Description

You are given two string arrays words1 and words2.

A string b is a subset of string a if every letter in b occurs in a including multiplicity.

A string a from words1 is universal if for every string b in words2, b is a subset of a.

Return an array of all the universal strings in words1. You may return the answer in any order.

Example 1:

Input: words1 = ["amazon","apple","facebook","google","leetcode"], words2 = ["e","o"]
Output: ["facebook","google","leetcode"]

Example 2:

Input: words1 = ["amazon","apple","facebook","google","leetcode"], words2 = ["l","e"]
Output: ["apple","google","leetcode"]

Constraints:

Idea

This is another question that uses counting/counter. For other similar questions, see the counting tag.

We could union all the counters (hashmaps) for all the words in words2. Let’s call this counter cnt.

We then compare cnt with the counter for each of the word in words1 and filter for the ones where cnt <= Counter(word).

Since Python has the library Counter, the Python implementation is the shortest.

let n = words1.len(), m = words2.len();
let l1 = max(words1.len()), l2 = max(words2.len());

Complexity: Time O(nl1+ml2)O(n*l1+m*l2), Space O(l1+l2)O(l1+l2).

Python

class Solution(object):
    """526 ms, 21.3 mb"""

    def wordSubsets(self, A: list[str], B: list[str]) -> list[str]:
        cnt = Counter()
        for b in B:
            cnt |= Counter(b)
        return [a for a in A if Counter(a) >= cnt]

Previous Post
LeetCode 1400 Construct K Palindrome Strings
Next Post
System Design - Event Loop for Concurrent Applications