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

单词规律(C++解法)

题目

给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。

这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着双向连接的对应规律。

示例1:

输入: pattern = "abba", s = "dog cat cat dog"
输出: true

示例 2:

输入: pattern = "abba", s = "dog cat cat fish"
输出: false

示例 3:

输入: pattern = "aaaa", s = "dog cat cat dog"
输出: false

C++代码

#include <iostream>
#include <string>
#include <unordered_map>
using namespace std;/*
* 单词规律的判断,和同构字符串相似
* 使用两个无序哈希表保存映射关系
* 设置一个临时变量保存单词
* 如果单词和字符有之间映射关系但是值不同,返回false
*/
bool wordPattern(string pattern, string s) {unordered_map<string, char> s2c;unordered_map<char, string> c2s;int len = s.size();int i = 0;for (auto c : pattern) {if (i >= len) {return false;}int j = i;while (j < len && s[j] != ' ') j++;const string& tmp = s.substr(i, j - i);if (s2c.count(tmp) && s2c[tmp] != c || c2s.count(c) && c2s[c] != tmp) {return false;}s2c[tmp] = c;c2s[c] = tmp;i = j + 1;}return true;
}
int main() {string pattern = "abba";string s = "dog cat cat dog";bool ans = wordPattern(pattern, s);cout << boolalpha << ans << endl;return 0;
}

分析

单词规律的判断,和同构字符串相似,使用两个无序哈希表保存映射关系,设置一个临时变量保存单词,如果单词和字符有之间映射关系但是值不同,返回 false。

问题

subsrt(pos, len) 函数表示从 pos开始 拷贝 len 个字符。

http://www.lryc.cn/news/198597.html

相关文章:

  • MySQL 主从复制原理
  • 构建嵌入式Linux rootfs根文件系统
  • 高速电路设计----第三章
  • 【微信小程序】6天精准入门(第4天:自定义组件及案例界面)附源码
  • pragma once与ifndef的区别
  • 52单片机独立键盘控制数码管计数
  • 完美解决 在将最终稿件上传到 IEEE PDF eXpress进行格式检查是出现“font not embedded“的问题 (不会出现自动压缩图像的现象)
  • 零基础学习CSS
  • 基于Flume+Kafka+Hbase+Flink+FineBI的实时综合案例(五)FineBI可视化
  • Python逆向爬虫案例: 某网站AES逆向解密
  • ONNX runtime本地终端部署
  • Linux性能优化--性能工具:特定进程CPU
  • 技术人员转岗产品经理,有优势吗?
  • 使用IDEA2022.1创建Maven工程出现卡死问题
  • Nuttx Syscall
  • HTTP协议中GET请求和POST请求的区别
  • 【广州华锐互动】利用VR开展施工现场安全培训,提高员工安全意识水平
  • Cornerstone for Mac:高效SVN管理的黄金标准
  • 数据结构之顺序表的模拟实现
  • R6G azide, 5-isomer具有良好的水溶性,2135330-71-9
  • Canvas系列绘制图片学习:绘制图片和渐变效果
  • AJAX为什么叫AJAX
  • 自动化测试中如何编写配置文件 ? 该使用什么工具 ? 一文详解使用ConfigParser读写配置文件
  • 文件批量管理:轻松复制备份并删除原文件
  • Linux高性能服务器编程 学习笔记 第十七章 系统监测工具
  • rabbitmq 消费者报错 ListenerExecutionFailedException NullPointerException
  • Java面试题:链表-合并两个排序的链表
  • Springboot结合Mockito写单元测试实践和原理
  • 操作系统之微内核架构
  • 24---WPF缓存