《嵌入式软件开发笔试与面试手册》:https://blog.nowcoder.net/zhuanlan/jvN8gj  《嵌入式软件笔试-2023年真题汇总》:https://blog.nowcoder.net/zhuanlan/0oDWVm    偏爱的字符  题目描述:  小李天生偏爱一些字符,对于一个字符串,他总是想把字符串中的字符变成他偏爱的那些字符。如果字符串中某个字符不是他所偏爱的字符,称为非偏爱字符,那么他会将该非偏爱字符替换为字符串中距离该字符最近的一个偏爱的字符。这里的距离定义即为字符在字符串中的对应下标之差的绝对值。如果有不止一个偏爱的字符距离非偏爱字符最近,那么小李会选择最左边的那个偏爱字符来替换该非偏爱字符,这样就保证了替换后的字符串是唯一的。小李的所有替换操作是同时进行的。  假定小李有m个偏爱的字符,依次为c1,c2...cm,当小李看到一个长度为n的字符串s时,请你输出小李在进行全部替换操作后形成的字符串。  输入描述  第一行输入两个正整数n,m。  接下来一行输入m个字符c1,c2...cm,每两个字符之间用空格隔开,表示小李偏爱的字符。  接下来一行输入一个字符串s。  1≤n≤100000,1≤m≤26,保证题目中所有的字符均为大写字符,小李偏爱的字符互不相同,且偏爱字符至少出现一次。  输出描述  输出一行字符串,表示小李将给定的字符串s替换后形成的字符串。  样例输入  12 4  Z G B A  ZQWEGRTBYAAI  样例输出  ZZZGGGBBBAAA  提示  字符Q为非偏爱字符,且偏爱字符Z距离它最近,所以替换成Z;同理E距离G最近,替换成G;  对于字符W,偏爱字符Z和G与其距离相同,所以替换为左边的Z;  .......  对于字符 I ,右边没有偏爱字符,左边第一个偏爱字符是A,所以替换成字符A。  同一个偏爱字符可能会在字符串中出现多次。  #include <iostream>#include <vector>#include <unordered_set>#include <algorithm>#include <limits>#include <string>using namespace std;int main() {    int n, m;    cin >> n >> m;        string loves;    cin.ignore();    getline(cin, loves);    unordered_set<char> loves_set(loves.begin(), loves.end());        string inputs;    getline(cin, inputs);        vector<int> loves_indexes;    for (int i = 0; i < inputs.length(); ++i) {        if (loves_set.find(inputs[i]) != loves_set.end()) {            loves_indexes.push_back(i);  // 如果 inputs 中的字符存在于 loves_set 中,记录其索引。        }    }        for (int i = 0; i < inputs.length(); ++i) {      
点赞 14
评论 6
全部评论

相关推荐

迷茫的大四🐶:哇靠,哥们,啥认证啊,副总裁实习,这么有实力嘛
一起聊美团
点赞 评论 收藏
分享
渴望wlb的牛油果很...:直说卡第一学历不就行了 非得拐弯抹角
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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