当前位置:网站首页>力扣每日一题-第44天-290. 单词规律
力扣每日一题-第44天-290. 单词规律
2022-08-01 07:25:00 【重邮研究森】
2022.7.31今天你刷题了吗?
题目:
给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。
这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着双向连接的对应规律。
分析:
给定两个字符串,需要判断它们是否满足匹配条件,举例如下:
“aabb” “cat cat dog dog”
相当于a=cat b=dog,则满足条件
“aabb” “cat dog cat dog”
因为a=cat,后面又有a=dog,则不满足
“aab” “cat cat cat cat”
数量对不上,不满足
因此,对于“cat cat”字符串,我们先把他保存在vector中,然后遍历“aabb”字符串,每次遍历需要判断两个条件。1.“aabb”中已经存在并且当前的aabb对应的cat不一样,则返回fasle。
2.“aabb”中不存在并且但前的cat也存在,则返回false
解析:
class Solution {
public:
bool wordPattern(string pattern, string s) {
unordered_map<char, string>u1;
vector<string>vec;
string s1;
for (int i = 0; i < s.size(); i++)
{
if (s[i] != ' ')
{
s1 += s[i];
}
else
{
vec.push_back(s1);
s1.clear();
}
}
vec.push_back(s1);
s1.clear();
if (pattern.size() != vec.size())
{
return false;
}
for (int i = 0; i < pattern.size(); i++)
{
if (u1.count(pattern[i]) && u1[pattern[i]] != vec[i])//aa存在,并且aa对于的值和现在不一样
{
return false;
}
else if (!(u1.count(pattern[i])))
{
for (auto it : u1)
{
if (it.second == vec[i])
{
return false;
}
}
}
u1[pattern[i]] = vec[i];
}
return true;
}
};
边栏推荐
- mysql中添加字段的相关问题
- C语言学习概览(一)
- MVVM项目开发(商品管理系统一)
- Golang:go开启web服务
- 图片无损压缩软件哪个好用:试试完全免费的JPG-C 图片批量修整压缩减肥工具吧 | 最新jpg批量修整工具下载
- 第02章 MySQL的数据目录【1.MySQL架构篇】【MySQL高级】
- R语言使用gt包和gtExtras包优雅地、漂亮地显示表格数据:gtExtras包的pad_fn函数与gt::fmt函数一起用于填充包含数值的特定列、对数据列的数值进行十进制对齐(从小数点对齐)
- 2022杭电多校第二场1011 DOS Card(线段树)
- Dart 异常详解
- Data organization -- singly linked list of the linear table
猜你喜欢
随机推荐
app 自动化 打开app (二)
dbeaver连接MySQL数据库及错误Connection refusedconnect处理
【南瓜书ML】(task4)神经网络中的数学推导(更新ing)
金山打字通 官网 下载
pytest接口自动化测试框架 | parametrize中ids的用法
05-SDRAM:仲裁
日志导致线程Block的这些坑,你不得不防
配置我的kitty
数据机构----线性表之单向链表
Guest brush SQL - 2
VoLTE基础学习系列 | 什么是SIP和IMS中的Forking
POJ2421道路建设题解
请问用flinksql写入数据到clickhouse需要引入什么依赖吗?
app 自动化 通过工具查看app 元素 (三)
Fist game copyright-free music download, League of Legends copyright-free music, can be used for video creation, live broadcast
仿牛客网讨论社区项目—项目总结及项目常见面试题
特殊的日子,值得纪念
测试工具(四)Jenkins环境搭建与使用
微信小程序请求封装
图像基本操作的其他内容