开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第7天,点击查看活动详情
1.描述
给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。
这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非空单词之间存在着双向连接的对应规律。
示例1:
输入: pattern = "abba", str = "dog cat cat dog"
输出: true
示例 2:
输入:pattern = "abba", str = "dog cat cat fish"
输出: false
示例 3:
输入: pattern = "aaaa", str = "dog cat cat dog"
输出: false
提示:
- 1 <= pattern.length <= 300
- pattern 只包含小写英文字母
- 1 <= s.length <= 3000
- s 只包含小写英文字母和 ' '
- s 不包含 任何前导或尾随对空格
- s 中每个单词都被 单个空格 分隔
2.分析
用哈希表一个一个储存pattern中的字符,并把str转换成数组
在储存过程中判断,如果这个字符出现过,则验证这个字符对应的单词是不是跟哈希表中这个字符储存的单词一致
如果这个字符没出现过,则判断哈希表存在不存在这个字符对应的单词,存在则是错误的。
因为应该是一一对应的关系。
3.AC代码
class Solution {
public boolean wordPattern(String pattern, String str) {
HashMap<Character, String> match = new HashMap<>();
String[] strs = str.split(" ");
if(strs.length != pattern.length()) return false;
for(int i = 0 ; i < pattern.length();i++){
if(match.containsKey(pattern.charAt(i))){
if(!match.get(pattern.charAt(i)).equals(strs[i])){
return false;
}
}else{
if(match.containsValue(strs[i])) return false;
else match.put(pattern.charAt(i),strs[i]);
}
}
return true;
}
}
4.总结
这种一般都可以使用哈希表解决。
此题需要注意的就是 是双向映射,不是单向映射。其他没啥。
参考
两种思路,98.94% 98.53% - 单词规律 - 力扣(LeetCode) (leetcode-cn.com)
简明易懂的题目分析及单Map方案 - 单词规律 - 力扣(LeetCode) (leetcode-cn.com)
用 String 数组代替 HashMap, 速度100% - 单词规律 - 力扣(LeetCode) (leetcode-cn.com)