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)

相关推荐
汀、人工智能8 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
沉鱼.448 小时前
第十二届题目
java·前端·算法
大熊背9 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
西岸行者10 小时前
BF信号是如何多路合一的
算法
大熊背10 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
罗西的思考11 小时前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef0611 小时前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi12 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
蚂蚁数据AntData13 小时前
破解AI“机器味“困境:HeartBench评测实践详解
大数据·人工智能·算法·机器学习·语言模型·开源
ZC跨境爬虫13 小时前
Python异步IO详解:原理、应用场景与实战指南(高并发爬虫首选)
爬虫·python·算法·自动化