前言
LeetCode的Weekly Contest 98的题目查找和替换模式,原题目描述如下:
你有一个单词列表 words 和一个模式 pattern,你想知道 words 中的哪些单词与模式匹配。
如果存在字母的排列 p ,使得将模式中的每个字母 x 替换为 p(x) 之后,我们就得到了所需的单词,那么单词与模式是匹配的。
(回想一下,字母的排列是从字母到字母的双射:每个字母映射到另一个字母,没有两个字母映射到同一个字母。)
返回 words 中与给定模式匹配的单词列表。
你可以按任何顺序返回答案。示例:
输入:words = ["abc","deq","mee","aqq","dkd","ccc"], pattern = "abb"
输出:["mee","aqq"]
解释:
"mee" 与模式匹配,因为存在排列 {a -> m, b -> e, ...}。
"ccc" 与模式不匹配,因为 {a -> c, b -> c, ...} 不是排列。
因为 a 和 b 映射到同一个字母。
解题思路
这道题目其实就是需要用一个数据结构去描述单词和模式之间的映射关系,而且模式和单词中的字母的关系是一对一,所以可以直接使用Map去解决这个问题。
实现代码
/**
* 查找和替换模式
* @param words
* @param pattern
* @return
*/
public List<String> findAndReplacePattern(String[] words, String pattern) {
List<String> result = new ArrayList<>();
char[] patternChars = pattern.toCharArray();
for (String word : words) {
char[] wordChars = word.toCharArray();
//是否匹配
boolean match = true;
//用于存储映射关系的Map
Map<Character, Character> map = new HashMap<>();
for (int i = 0; i < patternChars.length; i++) {
char p = patternChars[i];
char w = wordChars[i];
if (map.containsKey(p)) {//模式中的字母是否已经映射已经被映射
char value = map.get(p);
if (value != w) {
match = false;
break;
}
} else {
if(map.containsValue(w)){//判断单词中的字母是否被映射,防止模式多个字母都映射单词中的同一个字母
match = false;
break;
}else {
map.put(p, w);
}
}
}
if (match) {
result.add(word);
}
}
return result;
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。