华为机试 HJ81题解 | #字符串字符匹配#

字符串字符匹配

https://www.nowcoder.com/practice/22fdeb9610ef426f9505e3ab60164c93

#include <iostream>
#include <string>
#include <unordered_map>
#include <algorithm>
using namespace std;

bool MatchStr(string s, string t)
{
    bool bRet = false;
    unordered_map<char,int> sMap;
    unordered_map<char,int> tMap;
    for (auto ch : s) {
        sMap[ch]++;
    }
    for (auto ch2 : t) {
        tMap[ch2]++;
    }
    // 遍历sMap
    // 1.如果有字符在sMap中出现但不在tMap中出现,则返回false
    for (auto ch : sMap) {
        auto it = tMap.find(ch.first);
        if (it == tMap.end()) {
            return false;
        }
    }
    return true;
}

int main() {
    std::string s, t;
    while (getline(cin, s)) { // 注意 while 处理多个 case
        getline(cin, t);
        if (MatchStr(s, t)) {
            cout << "true" << std::endl;
        } else {
            cout << "false" << std::endl;
        }
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务