描述
你将得到一个字符串数组 A。
如果经过任意次数的移动,S == T,那么两个字符串 S 和 T 是特殊等价的。
一次移动包括选择两个索引 i 和 j,且 i % 2 == j % 2,交换 S[j] 和 S [i]。
现在规定,A 中的特殊等价字符串组是 A 的非空子集 S,这样不在 S 中的任何字符串与 S 中的任何字符串都不是特殊等价的。
返回 A 中特殊等价字符串组的数量。
- 1 <= A.length <= 1000
- 1 <= A[i].length <= 20
- All A[i] have the same length.
- All A[i] consist of only lowercase letters.
在线评测地址:领扣题库官网
样例1
示例 1:
输入:["a","b","c","a","c","c"]
输出:3
解释:3 组 ["a","a"],["b"],["c","c","c"]
样例2
示例 2:
输入:["aa","bb","ab","ba"]
输出:4
解释:4 组 ["aa"],["bb"],["ab"],["ba"]
样例3
示例 3:
输入:["abc","acb","bac","bca","cab","cba"]
输出:3
解释:3 组 ["abc","cba"],["acb","bca"],["bac","cab"]
样例4
示例 4:
输入:["abcd","cdab","adcb","cbad"]
输出:1
解释:1 组 ["abcd","cdab","adcb","cbad"]
题解
class Solution {
/**
* @param A: a string array
* @return: Return the number of groups of special-equivalent strings from A.
*/
public int numSpecialEquivGroups(String[] A) {
// write your code here
Set<String> s = new HashSet();
for (String str: A) {
int[] count = new int[52];
for (int i = 0; i < str.length(); ++i)
count[str.charAt(i) - 'a' + 26 * (i % 2)]++;
s.add(Arrays.toString(count));
}
return s.size();
}
}
更多题解参考:九章官网solution