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;

    }
};
相关推荐
oioihoii几秒前
拆解融合:测试开发,一个关于“更好”的悖论
c++
xiaoqider18 分钟前
C++模板进阶
开发语言·c++
移幻漂流29 分钟前
C/C++并发编程详解:如何写出优秀的并发程序
c语言·开发语言·c++
被星1砸昏头1 小时前
C++中的享元模式
开发语言·c++·算法
D_evil__1 小时前
【Effective Modern C++】第三章 转向现代C++:7. 在创建对象时注意区分()和{}
c++
Bruce_kaizy2 小时前
c++ dfs搜索算法——剪枝
c++·深度优先·剪枝
CSDN_RTKLIB2 小时前
【std::string】find函数
c++·stl
十五年专注C++开发2 小时前
浅谈CPU中的SIMD
c++·cpu·代码优化·simd
Yu_Lijing2 小时前
基于C++的《Head First设计模式》笔记——状态模式
c++·笔记·设计模式
顶点多余3 小时前
静态链接 vs 动态链接,静态库 vs 动态库
linux·c++·算法