学习剪枝的第一篇@_@
学习别人的剪枝,一剪就是两天@_@----
参看的这篇--
http://blog.csdn.net/libin56842/article/details/8962512
自己的小体会--
奇偶剪枝可以举两个一般的例子
比如样例
S.X.
..X.
..XD
....
转化为所需要的步数
S 6 X 2
6 5 X 1
5 4 X D
4 3 2 1
可以看到步数为奇数的时候,所需要的时间也为奇数
步数为偶数的时候,需要的时间也为偶数(因为是一秒走一步)
#include<iostream> #include<cstdio> #include<cstring> #include<algorithm> #include<math.h> using namespace std; int n,m,t,flag,di,dj,wall; int dir[4][2]={{0,-1},{0,1},{-1,0},{1,0}}; char map[10][10]; void dfs(int si,int sj,int cnt) { int tem; if(si<=0||sj<=0||si>n||sj>m) return; if(si==di&&sj==dj&&cnt==t) flag=1; if(flag) return; tem=t-cnt-abs(di-si)-abs(dj-sj); if(tem<0||tem%2) return; for(int i=0;i<4;i++) { if(map[si+dir[i][0]][sj+dir[i][1]]!='X') { map[si+dir[i][0]][sj+dir[i][1]]='X'; dfs(si+dir[i][0],sj+dir[i][1],cnt+1); map[si+dir[i][0]][sj+dir[i][1]]='.'; } } return; } int main() { int si,sj; while(scanf("%d %d %d",&n,&m,&t)!=EOF&&n&&m&&t) { wall=0; for(int i=1;i<=n;i++) { for(int j=1;j<=m;j++) { cin>>map[i][j]; if(map[i][j]=='S') {si=i;sj=j;} else if(map[i][j]=='D') { di=i;dj=j;} else if(map[i][j]=='X') wall++; } } if(n*m-wall<=t) { printf("NO "); continue; } flag=0; map[si][sj]='X'; dfs(si,sj,0); if(flag) printf("YES "); else printf("NO "); } }