290. 单词规律

290. 单词规律


题目链接:290. 单词规律

代码如下:

cpp 复制代码
class Solution {
public:
    bool wordPattern(string pattern, string s) {
        unordered_map<char,string> um;
        vector<string> strs;
        string str="";

        //把字符串中单词都保存到集合中
        for(int i=0;i<s.size();i++)
        {
            if(s[i]==' ')
            {
                strs.push_back(str);
                str="";
            }
            else
            {
                str+=s[i];
            } 
        }
        strs.push_back(str);

        //二者长度不同直接返回即可
        if(pattern.size()!=strs.size())
            return false;

        逐个对比
        for(int i=0;i<pattern.size();i++)
        {
            //未找到的情况
            if(um.find(pattern[i])==um.end())
            {
                看是否已于别的字母建立联系,是的话就直接返回,不满住一对一了
                for(auto it=um.begin();it!=um.end();it++)
                {
                    if(it->second==strs[i])
                        return false;
                }

                //插入
                um[pattern[i]]=strs[i];
            }
            //不满足一对一直接返回
            else if(strs[i]!=um[pattern[i]])
                return false;
        }

        return true;

    }
};
相关推荐
70asunflower4 小时前
CUDA编程指南基础知识点总结(5)
c++·人工智能·cuda
mjhcsp6 小时前
C++剪枝解析
c++·剪枝
wregjru6 小时前
【网络】5.HTTP 协议详解与实现
c++
Ralph_Y6 小时前
正则表达式
开发语言·c++·正则表达式
钓鱼的肝6 小时前
[GESP-4.2503.T2]二阶矩阵
c++·算法·矩阵
小小unicorn6 小时前
[微服务即时通讯系统]文件存储子服务的实现与测试
c++·redis·微服务·云原生·架构
草莓熊Lotso6 小时前
MySQL 数据库基础入门:从概念到实战
linux·运维·服务器·数据库·c++·人工智能·mysql
HalvmånEver6 小时前
6.高并发内存池的内存释放全流程
开发语言·c++·项目学习··高并发内存池
OxyTheCrack6 小时前
【C++】简述Observer观察者设计模式附样例(C++实现)
开发语言·c++·笔记·设计模式
小小unicorn6 小时前
[微服务即时通讯系统]3.服务端-环境搭建
数据库·c++·redis·微服务·云原生·架构