题意:给定两个字符串p和s,其中一个字符串p表示另一个字符串的pattern。例如,"aaa", 另一个字符串含有"good good good".求输入的两个字符串是否具有这样的匹配关系
题解:先把字符串s根据空格split存储在vector中方便遍历。我需要建立pattern和vector中的互为映射的关系。 可以保存两个map,其中一个map映射pattern到数组下标,另一个map映射string到数组下标。相当于特征值。
如果都没有出现过,那么给两个map赋值为下标,如果其中一个出现过,另一个没有出现过,那么返回false,如果对应的特征值不相等,返回false,最后返回true
cpp
class Solution {
public:
bool wordPattern(string p, string s) {
stringstream ss(s);
vector<string> v;
string w;
while(ss >> w) {
v.push_back(w);
}
unordered_map<char, int> mp1;
unordered_map<string, int> mp2;
if (v.size() != p.size()) return false;
for(int i = 0; i < p.size(); i++) {
if(!mp1.count(p[i]) && !mp2.count(v[i])) {
mp1[p[i]] = i;
mp2[v[i]] = i;
}
if(mp1.count(p[i]) ^ mp2.count(v[i])) {
return false;
}
if(mp1[p[i]] != mp2[v[i]]) {
return false;
}
}
return true;
}
};
时间复杂度: O ( n ) O(n) O(n) n为字符串长度
空间复杂度: O ( n ) O(n) O(n)