1. 程式人生 > >168、特殊等價字串陣列

168、特殊等價字串陣列

題目描述
你將得到一個字串陣列 A。

如果經過任意次數的移動,S == T,那麼兩個字串 S 和 T 是特殊等價的。

一次移動包括選擇兩個索引 i 和 j,且 i%2 == j%2,並且交換 S[j] 和 S [i]。

現在規定,A 中的特殊等價字串組是 A 的非空子集 S,這樣不在 S 中的任何字串與 S 中的任何字串都不是特殊等價的。

返回 A 中特殊等價字串組的數量。

示例 1:

輸入:[“a”,“b”,“c”,“a”,“c”,“c”]
輸出:3
解釋:3 組 [“a”,“a”],[“b”],[“c”,“c”,“c”]
示例 2:

輸入:[“aa”,“bb”,“ab”,“ba”]
輸出:4
解釋:4 組 [“aa”],[“bb”],[“ab”],[“ba”]
示例 3:

輸入:[“abc”,“acb”,“bac”,“bca”,“cab”,“cba”]
輸出:3
解釋:3 組 [“abc”,“cba”],[“acb”,“bca”],[“bac”,“cab”]
示例 4:

輸入:[“abcd”,“cdab”,“adcb”,“cbad”]
輸出:1
解釋:1 組 [“abcd”,“cdab”,“adcb”,“cbad”]

提示:

1 <= A.length <= 1000
1 <= A[i].length <= 20
所有 A[i] 都具有相同的長度。
所有 A[i] 都只由小寫字母組成。

題目意思不是很明白
難受
看一下官方的解釋
在這裡插入圖片描述

看了很長時間才明白:
比如從A中的第一個開始假如是abcd,那麼我將偶數交換為cbad那麼如果該陣列在那麼肯定是要放進去的,接下來將奇數交換,即:adcb如果在A中那麼放進去,那麼組成就是
[“abcd”,’“cbad”,“adcb”]那麼就算一個了
題目已經告訴你了:A[i]中的所有字串長度都相等,那麼我們就不需要判斷長度了,可以用一個int型的陣列

emm好像有點問題,為什麼第一個例子中[“a”,“a”]???

直接放程式碼吧

class Solution {
    public int numSpecialEquivGroups(String[] A) {
        Set<String> container = new HashSet<>();
        for(String s : A){
            container.add(sorted(s));
        }
        return container.size();
    }
    private String sorted(String s){
        char[] chars = s.toCharArray();
        for (int i = 0; i < chars.length; i++){
            for (int j = i + 2; j < chars.length; j += 2){
                if(chars[i] > chars[j]){
                    chars[i] ^= chars[j];
                    chars[j] ^= chars[i];
                    chars[i] ^= chars[j];
                }
            }
        }
        return new String(chars);
    }
}