题解 | #查找兄弟单词#

查找兄弟单词

https://www.nowcoder.com/practice/03ba8aeeef73400ca7a37a5f3370fe68

#include <iostream>
#include <string>
#include <vector>
#include <set>
#include <unordered_map>
using namespace std;

bool isBrother(string& word, string& target){
    if(word.size() != target.size()){
        return false;
    }
    if(word == target){
        return false;
    }
    unordered_map<char, int> dic;
    for(int i = 0; i < target.size(); ++i){
        ++dic[target[i]];
    }
    for(int i = 0; i < word.size(); ++i){
        if(dic.count(word[i])){
            --dic[word[i]];
            if(dic[word[i]] == 0){
                dic.erase(word[i]);
            }
        }
        else{
            return false;
        }
    }
    return dic.empty() ? true : false;
}

int main(int argc, char* argv[]){
    int n;
    cin >> n;
    multiset<string> dic;
    for(int i = 0; i < n; ++i){
        string word;
        cin >> word;
        dic.insert(word);
    }
    string target;
    cin >> target;
    int k;
    cin >> k;

    int count = 0;
    string kBrother;
    for(auto word : dic){
        if(isBrother(word, target)){
            ++count;
            if(count == k){
                kBrother = word;
            }
        }
    }
    cout << count << endl;
    if(!kBrother.empty()){
        cout << kBrother << endl;
    }

    return 0;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利&nbsp;有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的&nbsp;真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
点赞 评论 收藏
分享
06-20 17:42
东华大学 Java
凉风落木楚山秋:要是在2015,你这简历还可以月入十万,可惜现在是2025,已经跟不上版本了
我的简历长这样
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务