Harbour.Space Scholarship Contest 2021-2022 (open for everyone, rated, Div. 1 + Div. 2) D题解

传送门

题意

给定两个字符串\(a\)\(b\),要求依次输入\(a\)中的字符,并进行以下两种操作:

  • 输入当前字符
  • 不输入当前字符,并删除前一个字符

使得最终输入的字符和\(b\)字符相等。

思路

由于当前的字符不被删除就一定会被选上,因此考虑从后往前遍历\(a\)字符,如果与\(b\)字符相等就选上,否则删除。

代码

int n;
string a, b;
 
int main()
{
    int T;
    cin >> T;
    while (T --  ) 
    {
        cin >> a >> b;
 
        if (a.size() < b.size()) puts("NO");
        else 
        {
            int i, j;
            for (i = a.size() - 1, j = b.size() - 1; i >= 0 && j >= 0; i -- ) 
            {
                if (a[i] == b[j]) j -- ;
                else i -- ;
            }
 
            if (j >= 0) puts("NO");
            else puts("YES");
        }
    }
    
    return 0;
}
posted @ 2021-09-13 22:53  筱翼深凉  阅读(31)  评论(0编辑  收藏  举报