• [CF1303E] Erase Subsequences


    Solution

    不由分说地枚举分割点

    (f[i][j]) 表示原串处理到 (i)(s_1) 处理到 (j)(s_2) 最多能处理到哪里
    采用主动转移
    任意情况, (f[i][j] o f[i+1][j])
    如果 (s[i+1]=s_1[j+1]) ,那么 (f[i][j] o f[i+1][j+1])
    如果 (s[i+1]=s_2[f[i][j]+1]) ,那么 (f[i][j]+1 o f[i+1][j])
    时间复杂度 (O(n^3))

    #include <bits/stdc++.h>
    using namespace std;
    
    int n,m,l1,l2;
    char s[405],t[405],*s1,*s2;
    int f[405][405];
    
    void sh(int x,int &y) {
        y=max(x,y);
    }
    
    signed main() {
        ios::sync_with_stdio(false);
        int T;
        cin>>T;
        while(T--) {
            cin>>s+1>>t+1;
            n=strlen(s+1);
            m=strlen(t+1);
            int ans=0;
            for(int d=0;d<=m;d++) {
                s1=t;
                s2=t+d;
                l1=d;
                l2=m-d;
                memset(f,-0x3f,sizeof f);
                f[0][0]=0;
                {
                    int i=0,j=0;
                    sh(f[i][j],f[i+1][j]);
                    if(s[i+1]==s1[j+1]) sh(f[i][j],f[i+1][j+1]);
                    if(s[i+1]==s2[f[i][j]+1]) sh(f[i][j]+1,f[i+1][j]);
                }
                for(int i=1;i<=n;i++) {
                    for(int j=0;j<=min(l1,i);j++) {
                        sh(f[i][j],f[i+1][j]);
                        if(s[i+1]==s1[j+1]) sh(f[i][j],f[i+1][j+1]);
                        if(f[i][j]>=0 && s[i+1]==s2[f[i][j]+1]) sh(f[i][j]+1,f[i+1][j]);
                    }
                }
                if(f[n][l1]==l2) ans=1;
            }
            cout<<(ans>0?"YES":"NO")<<endl;
        }
    }
    
  • 相关阅读:
    python获取目录下文件夹名称
    【转载】robocopy的用法
    python使用windows注册表
    统计文本词频
    搞定:找不到该项目,请确认该项目的位置的办法
    set集合
    print显示设置
    用户登录接口(BATE)
    深浅拷贝
    C程序设计-----第2次作业
  • 原文地址:https://www.cnblogs.com/mollnn/p/12345851.html
Copyright © 2020-2023  润新知