leetcode_1941 检查是否所有字符出现次数相同

108 阅读1分钟

要求

给你一个字符串 s ,如果 s 是一个 好 字符串,请你返回 true ,否则请返回 false 。

如果 s 中出现过的 所有 字符的出现次数 相同 ,那么我们称字符串 s 是 好 字符串。

示例 1:

输入:s = "abacbc"
输出:true
解释:s 中出现过的字符为 'a''b''c' 。s 中所有字符均出现 2 次。

示例 2:

输入:s = "aaabb"
输出:false
解释:s 中出现过的字符为 'a''b''a' 出现了 3 次,'b' 出现了 2 次,两者出现次数不同。

提示:

  • 1 <= s.length <= 1000
  • s 只包含小写英文字母。

核心代码

class Solution:
    def areOccurrencesEqual(self, s: str) -> bool:
        c_f = collections.Counter(s)
        fs = set(list(c_f.values()))
        return len(fs) == 1

image.png

解题思路:我们使用collections.Counter这个方法对其中字符和数量进行统计,我们将得到的值进行集合处理,得到数量是1,则是好字符串,否则不是。