当前位置: 首页 > article >正文

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

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)


http://www.kler.cn/a/412114.html

相关文章:

  • 4.STM32之通信接口《精讲》之IIC通信---软件实现IIC《深入浅出》面试必备!
  • 计算机网络----基本概念
  • QML TableView 实例演示 + 可能遇到的一些问题(Qt_6_5_3)
  • 【VRChat 全身动捕】VIVE 手柄改 tracker 定位器教程,低成本光学动捕解决方案(持续更新中2024.11.26)
  • web day03 Maven基础 Junit
  • 星火一号开发板总结
  • 【Qt】Qt 在main.cpp中使用tr()函数报错
  • 【设计模式】【结构型模式(Structural Patterns)】之装饰模式(Decorator Pattern)
  • WordPress文章目录插件,LuckyWP Table of Contents自动生成文章插件
  • vue图片导入的几种方式及优劣对比
  • 通用网络安全设备之【防火墙】
  • YOLOX的正负样本分配问题
  • 如何使用Postman优雅地进行接口自动加密与解密
  • Rust学习(十):计算机科学简述
  • 网络基础二
  • 掌握 Spring 事务管理:深入理解 @Transactional 注解(二)
  • HTTP 缓存技术
  • Cannot find a valid baseurl for repo: centos-sclo-rh/x86_64
  • Linux的前台进程和后台进程
  • Git旧文件覆盖引发思考
  • Day 27 贪心算法 part01
  • 排序算法(六)--堆排序
  • Linux17 Git 指令
  • NIO三大组件
  • OpenAI 是怎么“压力测试”大型语言模型的?
  • C#中面试的常见问题005