1
0
Fork 0
mirror of https://gitlab.com/mfocko/LeetCode.git synced 2024-11-10 00:09:06 +01:00
LeetCode/go/find-common-characters.go
Matej Focko 9249f94a04
go: add «1002. Find Common Characters»
Signed-off-by: Matej Focko <me@mfocko.xyz>
2024-06-05 09:44:29 +02:00

34 lines
716 B
Go

package find_common_characters
func commonChars(words []string) []string {
A := int('a')
countCharacters := func(counters []int, word string) {
for _, c := range word {
counters[int(c)-A]++
}
}
setCommon := func(common []int, word []int) {
for i, count := range word {
common[i] = min(common[i], count)
}
}
commonCounters := make([]int, 26)
countCharacters(commonCounters, words[0])
for _, word := range words {
wordCounters := make([]int, 26)
countCharacters(wordCounters, word)
setCommon(commonCounters, wordCounters)
}
var result []string
for i, count := range commonCounters {
for count > 0 {
result = append(result, string(rune(A+i)))
count--
}
}
return result
}