「已注销」 2022-09-11 23:48 采纳率: 100%
浏览 52
已结题

给出2 个字符串 ,s,t。其中 s,t只包括a->r 的小写字母。

给出2 个字符串 ,s,t。其中 s,t只包括a->r 的小写字母。
进行 Q次询问( 1<=Q<=10^5),每次询问给出一个a->r 的子字符集L ,你按照顺序,取出 s和 t中,
由L 所包含字符组成的子序列s' ,t' 判断得到的 是否s'与 t'相同。
输入格式
输入的第一行包含 s。
第二行包含 t。
第三行包含 Q。
以下 Q 行每行包含一个询问字符串 l。在一个询问字符串中,所有字母均不相同。此外,所有询问字符串均已排
序,且没有一个询问字符串出现超过一次。
输出格式
对于每个询问,输出一行一个字符表示答案。如果 s' 和 t' 相同则输出 'Y',否则输出 'N'。
数据范围
对于100%的数据,1<=Q,|s|,|t|<=10^5
输入样例
aabcd
caabd
4
a
ac
abd
abcd
输出样例
YNYN
样例解释
对于第一个询问,只给出了字符a ,两个字符串均变为aa 。
对于第二个询问,第一个字符串变为aac 而第二个字符串变为caa

  • 写回答

1条回答 默认 最新

  • _GX_ 2022-09-12 03:43
    关注
    #include <iostream>
    #include <map>
    #include <string>
    
    int main() {
      std::string s, t, L;
      int n;
      std::cin >> s >> t;
      std::cin >> n;
      for (int i = 0; i < n; i++) {
        std::cin >> L;
        std::map<char, bool> set;
        for (auto c : L)
          set[c] = true;
        std::string s1, t1;
        for (auto c : s) {
          if (set.find(c) != set.end())
            s1 += c;
        }
        for (auto c : t) {
          if (set.find(c) != set.end())
            t1 += c;
        }
        std::cout << (s1 == t1 ? 'Y' : 'N');
      }
      return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月21日
  • 已采纳回答 9月13日
  • 创建了问题 9月11日

悬赏问题

  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据
  • ¥15 Vue3 大型图片数据拖动排序