给你一个字符数组 keys
,由若干 互不相同 的字符组成。还有一个字符串数组 values
,内含若干长度为 2 的字符串。另给你一个字符串数组 dictionary
,包含解密后所有允许的原字符串。请你设计并实现一个支持加密及解密下标从 0 开始字符串的数据结构。
字符串 加密 按下述步骤进行:
c
,先从 keys
中找出满足 keys[i] == c
的下标 i
。values[i]
替换字符 c
。字符串 解密 按下述步骤进行:
s
,找出满足 values[i] == s
的一个下标 i
。如果存在多个有效的 i
,从中选择 任意 一个。这意味着一个字符串解密可能得到多个解密字符串。keys[i]
替换 s
。实现 Encrypter
类:
Encrypter(char[] keys, String[] values, String[] dictionary)
用 keys
、values
和 dictionary
初始化 Encrypter
类。String encrypt(String word1)
按上述加密过程完成对 word1
的加密,并返回加密后的字符串。int decrypt(String word2)
统计并返回可以由 word2
解密得到且出现在 dictionary
中的字符串数目。
示例:
输入: ["Encrypter", "encrypt", "decrypt"] [[['a', 'b', 'c', 'd'], ["ei", "zf", "ei", "am"], ["abcd", "acbd", "adbc", "badc", "dacb", "cadb", "cbda", "abad"]], ["abcd"], ["eizfeiam"]] 输出: [null, "eizfeiam", 2] 解释: Encrypter encrypter = new Encrypter([['a', 'b', 'c', 'd'], ["ei", "zf", "ei", "am"], ["abcd", "acbd", "adbc", "badc", "dacb", "cadb", "cbda", "abad"]); encrypter.encrypt("abcd"); // 返回 "eizfeiam"。 // 'a' 映射为 "ei",'b' 映射为 "zf",'c' 映射为 "ei",'d' 映射为 "am"。 encrypter.decrypt("eizfeiam"); // return 2. // "ei" 可以映射为 'a' 或 'c',"zf" 映射为 'b',"am" 映射为 'd'。 // 因此,解密后可以得到的字符串是 "abad","cbad","abcd" 和 "cbcd"。 // 其中 2 个字符串,"abad" 和 "abcd",在 dictionary 中出现,所以答案是 2 。
提示:
1 <= keys.length == values.length <= 26
values[i].length == 2
1 <= dictionary.length <= 100
1 <= dictionary[i].length <= 100
keys[i]
和 dictionary[i]
互不相同1 <= word1.length <= 2000
1 <= word2.length <= 200
word1[i]
都出现在 keys
中word2.length
是偶数keys
、values[i]
、dictionary[i]
、word1
和 word2
只含小写英文字母encrypt
和 decrypt
总计 200
次