Leetcode 290 word Pattern

题意:给定两个字符串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)

相关推荐
睡觉就不困鸭11 分钟前
第十七天 翻转字符串里的单词
数据结构·算法·哈希算法·散列表
ulias21215 分钟前
leetcode热题 - 4
算法·leetcode·职场和发展
学术阿凡提16 分钟前
Spring Boot 优雅实现异步调用:从入门到自定义线程池与异常处理
java·数据库·算法
圣保罗的大教堂20 分钟前
leetcode 1559. 二维网格图中探测环 中等
leetcode
MicroTech202526 分钟前
微算法科技(NASDAQ :MLGO)量子化边缘检测技术:重塑图像处理的新范式
图像处理·科技·算法
WolfGang00732131 分钟前
代码随想录算法训练营 Day47 | 图论 part05
算法·图论
猿长大人39 分钟前
算法 | 轮廓提取随笔 —— 关于像素、阈值和直觉的碎碎念
图像处理·算法
啦啦啦_99991 小时前
1. 线性回归之 向量&矩阵
算法·矩阵·线性回归
DolphinDB智臾科技1 小时前
DolphinDB 走进东南大学 | 新型电力系统高频数据处理与算法落地实战
算法
Zzzzmo_1 小时前
前缀和算法
算法·前缀和