【C++】每日一题 290 单词规律

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

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

cpp 复制代码
#include <string>
#include <unordered_map>
#include <sstream>

using namespace std;

class Solution {
public:
    bool wordPattern(string pattern, string s) {
        unordered_map<char, string> charToWord;
        unordered_map<string, char> wordToChar;
        istringstream ss(s);
        string word;
        
        for (char c : pattern) {
            if (!(ss >> word)) // 如果没有更多单词了,返回 false
                return false;
            
            // 如果当前字符已经在哈希表中,检查是否对应的单词匹配
            if (charToWord.find(c) != charToWord.end()) {
                if (charToWord[c] != word)
                    return false;
            } else {
                // 如果当前单词已经在哈希表中,检查是否对应的字符匹配
                if (wordToChar.find(word) != wordToChar.end()) {
                    if (wordToChar[word] != c)
                        return false;
                } else {
                    // 如果当前字符和单词都不在哈希表中,进行映射
                    charToWord[c] = word;
                    wordToChar[word] = c;
                }
            }
        }
        
        // 检查是否还有多余的单词
        return !(ss >> word);
    }
};

遍历 pattern 中的每个字符,同时使用istringstream从字符串 s 中提取单词。在遍历过程中,建立字符到单词的映射和单词到字符的映射,并检查映射是否正确。如果遍历完 pattern 后,仍然存在未匹配的单词,则返回 false。

时间复杂度分析

这个算法的时间复杂度取决于字符串 s 中单词的数量和 pattern 的长度,设 n 为 s 中单词的数量,m 为 pattern 的长度:

遍历 pattern 的过程中,需要将每个字符映射到对应的单词,这需要 O(m) 的时间复杂度。

使用istringstream从字符串 s 中提取单词的过程中,需要 O(n) 的时间复杂度。

最后检查是否还有多余的单词,需要 O(1) 的时间复杂度。

因此,总的时间复杂度为 O(m + n)。

空间复杂度分析

空间复杂度主要取决于哈希表的存储,哈希表的大小取决于 pattern 中唯一字符的数量和 s 中单词的数量:

哈希表 charToWord 存储了 pattern 中的每个字符到对应的单词,空间复杂度为 O(字符集大小)。

哈希表 wordToChar 存储了 s 中的每个单词到对应的字符,空间复杂度也为 O(单词数量)。

因此,总的空间复杂度为 O(字符集大小 + 单词数量)。

相关推荐
软件开发技术局31 分钟前
撕碎QT面具(8):对控件采用自动增加函数(转到槽)的方式,发现函数不能被调用的解决方案
开发语言·qt
周杰伦fans2 小时前
C#中修饰符
开发语言·c#
yngsqq2 小时前
c# —— StringBuilder 类
java·开发语言
赔罪2 小时前
Python 高级特性-切片
开发语言·python
专注VB编程开发20年2 小时前
除了 EasyXLS,加载和显示.xlsx 格式的excel表格,并支持单元格背景色、边框线颜色和粗细等格式化特性
c++·windows·excel·mfc·xlsx
子豪-中国机器人3 小时前
2月17日c语言框架
c语言·开发语言
夏天的阳光吖3 小时前
C++蓝桥杯基础篇(四)
开发语言·c++·蓝桥杯
oioihoii4 小时前
C++17 中的 std::to_chars 和 std::from_chars:高效且安全的字符串转换工具
开发语言·c++
张胤尘4 小时前
C/C++ | 每日一练 (2)
c语言·c++·面试
秋窗75 小时前
Mac下Python版本管理,适用于pyenv不起作用的情况
开发语言·python·macos