当前位置:编程学习 > C/C++ >>

hdu 4545(水题,不是DP)

这道题看到有人用最长公共子序列去做,其实完全用不上,直接遍历一遍就行了,就是一个水题。


[cpp]
#include<stdio.h>  
#include<string.h>  
#define N 1005  
int main() 

    char s1[N],s2[N]; 
    int mark[27][27]; 
    int i,j; 
    int flag; 
    int T; 
    char x,y; 
    scanf("%d",&T); 
    int count=1; 
    while(T--) 
    { 
        getchar(); 
        gets(s1); 
        gets(s2); 
        int n; 
        scanf("%d",&n); 
        memset(mark,0,sizeof(mark)); 
        while(n--) 
        { 
            getchar(); 
            scanf("%c %c",&x,&y); 
            mark[x-'a'+1][y-'a'+1]=1; 
        } 
        int ln1,ln2; 
        ln1=strlen(s1); 
        ln2=strlen(s2); 
        i=0; 
        j=0; 
        flag=0; 
        for(i=0;i<ln1;i++) 
        { 
            if(j==ln2) 
                break; 
            if(s1[i]==s2[j]) 
            { 
                j++; 
                continue; 
            } 
            while(s2[j]!=s1[i]) 
            { 
                if(j==ln2) 
                { 
                    flag=1; 
                    break; 
                } 
                if(mark[s2[j]-'a'+1][s1[i]-'a'+1]==1) 
                { 
                    j++; 
                    break; 
                } 
                else  
                    j++; 
            } 
        } 
        if(!flag) 
            printf("Case #%d: happy\n",count++); 
        else 
            printf("Case #%d: unhappy\n",count++); 
    } 
    return 0; 

补充:软件开发 , C++ ,
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,