1 条题解

  • 0
    @ 2025-2-14 21:20:39

    C++ :

    #include<iostream>
    #include<string>
    #include<algorithm>
    #include<cstring>
    using namespace std;
    const int N(55);
    int f[N][N]={0};
    
    int main()
    {
        string s1,s2;
        int i,j,len1,len2;
        while (cin>>s1>>s2)
        {    
            memset(f,0,sizeof(f));       
            len1=s1.size();  len2=s2.size();
            for (i=1;i<=len1;i++)
                for (int  j=1;j<=len2;j++)
                {                 
                    f[i][j]=f[i-1][j-1]+(s1[i-1]==s2[j-1]?2:0); 
                    for (int k=1;k<i;k++) f[i][j]=max(f[i][j],f[k][j]-1);
                    for (int k=1;k<j;k++) f[i][j]=max(f[i][j],f[i][k]-1);
                }
            cout<<f[len1][len2]<<endl;
        }
        return 0;
    }
    
    
    • 1

    信息

    ID
    760
    时间
    1000ms
    内存
    128MiB
    难度
    (无)
    标签
    递交数
    0
    已通过
    0
    上传者