[每日一题]2506.统计相似字符串对的数目

2506. 统计相似字符串对的数目 给你一个下标从 0 开始的字符串数组 words

如果两个字符串由相同的字符组成,则认为这两个字符串 相似 。

  • 例如,”abca” 和 “cba” 相似,因为它们都由字符 ‘a’、’b’、’c’ 组成。
  • 然而,”abacba” 和 “bcfd” 不相似,因为它们不是相同字符组成的。

请你找出满足字符串 words[i] 和 words[j] 相似的下标对 (i, j) ,并返回下标对的数目,其中 0 <= i < j <= word.length - 1 。

输入:words = [“aba”,”aabb”,”abcd”,”bac”,”aabc”] 输出:2 解释:共有 2 对满足条件:

  • i = 0 且 j = 1 :words[0] 和 words[1] 只由字符 ‘a’ 和 ‘b’ 组成。
  • i = 3 且 j = 4 :words[3] 和 words[4] 只由字符 ‘a’、’b’ 和 ‘c’ 。

输入:words = [“aabb”,”ab”,”ba”] 输出:3 解释:共有 3 对满足条件:

  • i = 0 且 j = 1 :words[0] 和 words[1] 只由字符 ‘a’ 和 ‘b’ 组成。
  • i = 0 且 j = 2 :words[0] 和 words[2] 只由字符 ‘a’ 和 ‘b’ 组成。
  • i = 1 且 j = 2 :words[1] 和 words[2] 只由字符 ‘a’ 和 ‘b’ 组成。

提示:

  • 1 <= words.length <= 100
  • 1 <= words[i].length <= 100
  • words[i] 仅由小写英文字母组成

Solutions

class Solution {
    public int similarPairs(String[] words) {
        int count = 0;
        int len = words.length;
        int [][]arr = new int[len][26];
        for (int i = 0; i < len; i++) {
            for(char a : words[i].toCharArray()){
                arr[i][a-'a'] = 1;
            }
        }
        for (int i = 0; i < len; i++) {
            for (int j = i+1; j < len; j++) {
                if(Arrays.equals(arr[i],arr[j])){
                    count++;
                }
            }
        }
        return count;
    }
}

Ideas

  • 1.哈希表 + 位运算(状态压缩)

    由于单词只由小写字母构成,所以可以把单词中字符是否出现的状态用int的低26位表示,不同单词经过位运算操作后得到相同的值, 那么就可以说明这两个单词由相同类型的字符组成。我们可以维护一个哈希表,key记录单词压缩后的int值, value记录单词个数。 答案要求的是满足条件的对数!所以应该把它们依次加起来,注意一定是先加入答案 再自增! 比如某个状态的value为4 表示该字符组合的单词有4个 共有 3 + 2 + 1 + 0 = 6对!不会把4加入答案!