-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy path1002.FindCommonCharacters.py
46 lines (40 loc) · 1.41 KB
/
1002.FindCommonCharacters.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
"""
Given an array A of strings made only from lowercase letters, return a
list of all characters that show up in all strings within the list
(including duplicates). For example, if a character occurs 3 times in
all strings but not 4 times, you need to include that character three
times in the final answer.
You may return the answer in any order.
Example:
Input: ["bella","label","roller"]
Output: ["e","l","l"]
Example:
Input: ["cool","lock","cook"]
Output: ["c","o"]
Note:
1. 1 <= A.length <= 100
2. 1 <= A[i].length <= 100
3. A[i][j] is a lowercase letter
"""
#Difficulty:Easy
#83 / 83 test cases passed.
#Runtime: 36 ms
#Memory Usage: 14.2 MB
#Runtime: 36 ms, faster than 97.60% of Python3 online submissions for Find Common Characters.
#Memory Usage: 14.2 MB, less than 38.79% of Python3 online submissions for Find Common Characters.
class Solution:
def commonChars(self, A: List[str]) -> List[str]:
db = {}
result = []
chars = set(A[0])
for char in chars:
db[char] = A[0].count(char)
for word in A[1:]:
for key in db.keys():
if key not in word:
db[key] = 0
else:
db[key] = min(db[key], word.count(key))
for key, value in db.items():
result.extend([key] * value)
return result