2514. Count Anagrams
Read the full problem statement on LeetCode.
Difficulty: hard Acceptance: 35% Topics: Hash Table, Math, String, Combinatorics, Counting
View full problem on LeetCode Reading material
Reference solution (spoiler · python)
# Time: O(n)
# Space: O(n)
import collections
# combinatorics
class Solution(object):
def countAnagrams(self, s):
"""
:type s: str
:rtype: int
"""
MOD = 10**9+7
fact, inv, inv_fact = [[1]*2 for _ in xrange(3)]
def lazy_init(n):
while len(inv) <= n: # lazy initialization
fact.append(fact[-1]*len(inv) % MOD)
inv.append(inv[MOD%len(inv)]*(MOD-MOD//len(inv)) % MOD) # https://cp-algorithms.com/algebra/module-inverse.html
inv_fact.append(inv_fact[-1]*inv[-1] % MOD)
def factorial(n):
lazy_init(n)
return fact[n]
def inv_factorial(n):
lazy_init(n)
return inv_fact[n]
def count(j, i):
result = 1
cnt = collections.Counter()
for k in xrange(j, i+1):
cnt[s[k]] += 1
result = factorial(sum(cnt.itervalues()))
for c in cnt.itervalues():
result = (result*inv_factorial(c))%MOD
return result
result = 1
j = 0
for i in xrange(len(s)):
if i+1 != len(s) and s[i+1] != ' ':
continue
result = (result*count(j, i))%MOD
j = i+2
return result
Solution from kamyu104/LeetCode-Solutions · MIT
Similar questions