zoukankan      html  css  js  c++  java
  • POJ 2192 Zipper (简单DP)

    POJ 2192 Zipper

    题目传送门

    题意:

    给出你三个字符串,问你能否把前两个字符串混合成第三个字符串,使得每个字母在原字符串中的前后顺序不改变。

    解题过程:

    考虑DP,可以用f[i][j]表示第一个字符串枚举到第i位,第二个字符串枚举到第j位时,能否混合成前第三个字符串前i+j位。然后就是简单的转移了。最后f[len1][len2]就是答案了。

    AC代码:

    #include <iostream>  
    #include <cmath>  
    #include <vector>  
    #include <cstdlib>  
    #include <cstdio>  
    #include <cstring>  
    #include <queue>  
    #include <stack>  
    #include <list>  
    #include <algorithm>  
    #include <map>  
    #include <set>  
    const int maxn=205;
    
    int T;
    char s1[maxn],s2[maxn],c[maxn*2];
    int len1,len2,len;
    bool f[maxn][maxn];
    
    int main()  
    {  
        scanf("%d",&T);
        int t=1;
        while(T--)
        {
            printf("Data set %d: ",t++);
            scanf("%s%s%s",s1+1,s2+1,c+1); 
            len1=strlen(s1+1);
            len2=strlen(s2+1);
            len=strlen(c+1);
            memset(f,0,sizeof f);
            for(int i=1;i<=len1;i++)
            {
                if(s1[i]==c[i])
                {
                    f[i][0]=1;
                }
                else break;
            }
            for(int i=1;i<=len2;i++)
            {
                if(s2[i]==c[i])
                {
                    f[0][i]=1;
                }
                else break;
            }
            for(int i=1;i<=len1;i++)
            {
                for(int j=1;j<=len2;j++)
                {
                    if(s1[i]==c[i+j]&&f[i-1][j])
                    {
                        f[i][j]=1;
                    }
                    if(s2[j]==c[i+j]&&f[i][j-1])
                    {
                        f[i][j]=1;
                    }
                }
            }
            if(f[len1][len2])
            printf("yes
    ");
            else printf("no
    ");
        }
        return 0;
    }  

    本人蒟蒻OIer一枚,欢迎加QQ:840776708一起学习蛤。

    「我不敢下苦功琢磨自己,怕终于知道自己并非珠玉;然而心中既存着一丝希冀,便又不肯甘心与瓦砾为伍。」
  • 相关阅读:
    也谈谈我面试的经历
    synchronized和lock比对
    数据结构之查找
    iptable和tcpdump的先后顺序
    iptable的四表五链
    iptable规则的执行顺序
    curl指令的坑
    k8s 网络模型解析之实践
    如何创建一个img文件并且mount 它
    k8s 网络模型解析之原理
  • 原文地址:https://www.cnblogs.com/Apocrypha/p/9433671.html
Copyright © 2011-2022 走看看