HDU 1501 Zipper
2011-09-17 19:41
323 查看
刚开始知道要用记忆化搜索,然而自己仍然去试了一下暴力DFS,TLE之后我就死心了,就利用记忆化搜索,就是用一个标记hash标记已经拜访过的;
#include<stdio.h> #include<stdlib.h> #include<string.h> char num1[224],num2[224],num3[424]; int len1,len2,len3,flag,hash[224][224]; void DFS( int a,int b,int c ) { if( len3==c ) { flag=1; return ; } if( hash[a][b]==1 ) //如果该点已经标记就代表该点一下的所有路线都访问过,就不需要继续深搜。
return ; hash[a][b]=1; if( num1[a]==num3[c] ) { DFS( a+1,b,c+1 ); } if( num2[b]==num3[c] ) { DFS( a,b+1,c+1 ); } } int main() { int T; scanf( "%d",&T ); for( int i=1; i<=T; i++ ) { flag=0; scanf( "%s%s%s",num1,num2,num3 ); len1=strlen( num1 ),len2=strlen( num2 ),len3=strlen( num3 ); memset( hash,0,sizeof( hash ) ); DFS( 0,0,0 ); printf(flag== 1? "Data set %d: yes\n": "Data set %d: no\n", i); } return 0; }
相关文章推荐
- HDU 1501 Zipper(DFS)
- hdu1501——Zipper
- 【DFS(记忆化)】hdu 1501 Zipper
- HDU 1501 Zipper(dp)
- HDU1501 Zipper(DFS+记忆化搜索)
- HDU 1501 Zipper(DP/记忆化搜索)
- hdu 1501 Zipper(记忆化DFS)
- hdu 1501 Zipper
- HDU 1501 Zipper 记忆化搜索
- HDU 1501 Zipper(DFS)
- HDU 1501 Zipper
- HDU 1501 & POJ 2192 Zipper(dp记忆化搜索)
- hdu 1501 Zipper(DP)
- hdu 1501 Zipper
- hdu 1501 Zipper dp
- HDU 1501 Zipper
- HDU--杭电--1501--Zipper--深搜、DP都好
- Hdu 1501 Zipper【dfs】
- HDU 1501 Zipper (DFS)
- hdu 1501 Zipper(DFS)