poj2192 hdu1501 Zipper

                     dp[i][j]表示第一个字符串前i个与第二个字符串前j个字符能否组成第三个字符串前i+j个;

                       

#include<iostream>
#include<cstring>
#include<cstdio> 
using namespace std;
int main()
{
	int T;
	cin>>T;
	char str1[205], str2[205], str3[505];
	int len1, len2, len3;
	bool dp[505][505];
	for(int k=1; k<=T; k++)
	{
		scanf("%s%s%s", str1+1, str2+1, str3+1);
		memset(dp, 0, sizeof(dp));
		
		len1 = strlen(str1);
		len2 = strlen(str2);
		len3 = strlen(str3);
		
    	//这三个任意初始化就可以 
		//但是不知为啥, 不初始化就不对,明明这三个使用不到的。我因为没初始化WR了n次	
		str1[0]='1';
		str2[0]='2';
		str3[0]='3';
		dp[0][0]=1;
	
   	    for(int i=0; i<len1; i++)
           for(int j=0; j<len2; j++)
           {
	             if((i>=1&&str3[i+j] == str1[i]&&dp[i-1][j]) || (j>=1&&str3[i+j] == str2[j]&&dp[i][j-1]))
				       dp[i][j]=1;
           }
   	      printf( "Data set %d: ", k);
          if(dp[len1-1][len2-1])  printf( "yes\n");
          else printf( "no\n");
	}
} 

你可能感兴趣的:(poj2192 hdu1501 Zipper)