算法-单词规律(290)

leetcode题目链接

这道题用哈希表来解决 一个哈希表存放从单词到字符的映射,一个存放从字符到单词的映射,依照空格分隔字符,并将每个字符存放到vector字符数组,

遍历 pattern,对于每个字符 c 和对应的单词 w

检查 charToWord 中是否已经存在映射,若存在且不匹配则返回 false

检查 wordToChar 中是否已经存在映射,若存在且不匹配则返回 false

否则,建立新的映射。

遍历结束没有发现不匹配,则返回true。

代码如下:

cpp 复制代码
class Solution {
public:
    bool wordPattern(string pattern, string s) {
   unordered_map<char, string> charToWord;
    unordered_map<string, char> wordToChar;
    vector<string> words;
    int pos = 0, start = 0;

    // 用空格分割字符串 s
    while ((pos = s.find(' ', start)) != string::npos) {
        words.push_back(s.substr(start, pos - start));
        start = pos + 1;
    }
    words.push_back(s.substr(start));

    // 如果单词数量和模式长度不匹配,返回 false
    if (words.size() != pattern.length()) {
        return false;
    }

    for (int i = 0; i < pattern.length(); ++i) {
        char c = pattern[i];
        string w = words[i];

        // 检查字符是否已映射到某个单词
        if (charToWord.find(c) != charToWord.end()) {
            if (charToWord[c] != w) {
                return false; // 不匹配返回 false
            }
        } else {
            charToWord[c] = w; // 新映射
        }

        // 检查单词是否已映射到某个字符
        if (wordToChar.find(w) != wordToChar.end()) {
            if (wordToChar[w] != c) {
                return false; // 不匹配返回 false
            }
        } else {
            wordToChar[w] = c; // 新映射
        }
    }

    return true;
    }
};

这里的s.find('',start)即从start的位置找到第一个空格的位置。

string::npos 是一个常数,表示查找操作未找到时的返回值。它通常用于判断 find 方法是否成功找到指定字符或子字符串。如果 find 返回 string::npos,意味着未找到。

相关推荐
KaMeidebaby8 小时前
卡梅德生物技术快报|Western Blot 实验应用:肺肠轴机制研究全流程技术解析
前端·数据库·人工智能·算法·百度
AhriProGramming8 小时前
计算机科普故事会-<2>见微知著
算法
BD4SXV8 小时前
线性二次调节器(Linear Quadratic Regulator,LQR)的无限时域最优控制求解与黎卡提方程
算法·自动化
ST——Jess8 小时前
2026年度传统文化数字化与命理科技(Ethno-tech)行业趋势研究报告:专业级数智工作台的技术壁垒与评测标准
人工智能·科技·算法·架构
Matrix_119 小时前
第13篇:非线性位移场——漩涡、鱼眼、水波纹与球面化
图像处理·算法
金牌归来发现妻女流落街头9 小时前
【LeetCode 第207题】
算法·leetcode·拓扑·领接表
熬夜敲代码的猫9 小时前
AVL树(C++详解版)
数据结构·c++·算法
-To be number.wan9 小时前
算法日记 | STL-MAP
c++·算法
cjp5609 小时前
015. UG 二次开发,拉伸草图生成实体类,高级草图类封装
算法
Eric 辰东10 小时前
【C 语言程序的编译和链接】详解编译链接过程
c语言·笔记·算法·学习方法