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;
}

 
                
             
         浙公网安备 33010602011771号
浙公网安备 33010602011771号