-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathremove-letter-to-equalize-frequency_2432.py
43 lines (29 loc) · 1.47 KB
/
remove-letter-to-equalize-frequency_2432.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
# You are given a 0-indexed string word, consisting of lowercase English letters. You need to select one index and remove the letter at that index from word so that the frequency of every letter present in word is equal.
# Return true if it is possible to remove one letter so that the frequency of all letters in word are equal, and false otherwise.
# Note:
# The frequency of a letter x is the number of times it occurs in the string.
# You must remove exactly one letter and cannot choose to do nothing.
# Example 1:
# Input: word = "abcc"
# Output: true
# Explanation: Select index 3 and delete it: word becomes "abc" and each character has a frequency of 1.
# Example 2:
# Input: word = "aazz"
# Output: false
# Explanation: We must delete a character, so either the frequency of "a" is 1 and the frequency of "z" is 2, or vice versa. It is impossible to make all present letters have equal frequency.
# Constraints:
# 2 <= word.length <= 100
# word consists of lowercase English letters only.
# ---------------------------------------Runtime 40 ms Beats 24.68% Memory 16.47 MB Beats 83.09%---------------------------------------
from collections import Counter, deque
class Solution:
def equalFrequency(self, word: str) -> bool:
words = deque(word)
i = 0
while i < len(word):
w = words.popleft()
if len(set(Counter(words).values())) == 1:
return True
words.append(w)
i += 1
return False