hdu2821 Pusher 深搜


今天一大早起来做这道题。做到了下午4点半。。。终于把他给AC了。。。好多小错误。。弱智错误。。我现在居然也犯。。。哎。。各种无厘头。。。难道是得知我们有集训室了之后太高兴了么。。。。


题目链接:

http://acm.hdu.edu.cn/showproblem.php?pid=2821

如果想明白题意,就先去玩一下这个游戏。。然后就不怕理解不了题意了。。

game链接:http://www.hacker.org/push/


思路:

看上去很吓人。。实际上就是个简单的深搜而已,怪不得夏天的风把他放在搜索level1里面。。。但是害死我了。。。

代码:

#include 
#include 
#include 
using namespace std;

const int maxn = 30;

int R, C;
int num[maxn][maxn];
int dir[4][2] = {{1,0},{-1,0},{0,1},{0,-1}};
char DIR[] = "DURL";
int rec[1000];
int ansx, ansy;
bool flag;
int all;		//格子总数

bool judge(int x, int y)
{
	if (x < 0 || y < 0 || x >= R || y >= C) return false;
	return true;
}

void dfs(int x, int y, int ansnum)
{
	if (all == ansnum)
	{
		flag = true;
		return ;
	}
	if (flag) return ;

	int i, j;
	for (i=0; i<4 && !flag; i++)
	{
		if (num[x+dir[i][0]][y+dir[i][1]]) continue;	//如果此方向紧挨着格子,就continue。。ps:这么个小错误,卡了我好几个小时。。。T T。。。
		for (j=1; !flag; j++)
		{
			int x3 = x + (j+2) * dir[i][0], y3 = y + (j+2) * dir[i][1];
			if (!judge(x3, y3)) break;
			int x1 = x + j * dir[i][0], y1 = y + j * dir[i][1];
			int x2 = x + (j+1) * dir[i][0], y2 = y + (j+1) * dir[i][1];
			if (num[x2][y2] > 0 && num[x1][y1] == 0)
			{
				rec[ansnum] = i;
				int old = num[x2][y2];
				num[x3][y3] += (old - 1);
				num[x2][y2] = 0;

				dfs(x2, y2, ansnum+1);

				num[x2][y2] = old;
				num[x3][y3] -= (old - 1);
				break;
			}
		}
	}
}

int main()
{
	while (scanf("%d %d", &C, &R) != EOF)
	{
		int i, j;
		getchar();
		all = 0;
		for (i=0; i= 'a' && c <= 'z')
				{
					num[i][j] = c - 'a' + 1;
					all += num[i][j];
				}
				else
					num[i][j] = 0;
			}
			getchar();
		}
		flag = false;
		for (i=0; i 0 && num[x1][y1] == 0)
						{
							memset(rec, -1, sizeof(rec));
							rec[0] = k;
							int old = num[x2][y2];
							num[x3][y3] += (old - 1);
							num[x2][y2] = 0;

							dfs(x2, y2, 1);

							if (flag)
							{
								ansx = i;
								ansy = j;
							}

							num[x2][y2] = old;
							num[x3][y3] -= (old - 1);
						}
					}
				}
			}
		}
		printf("%d\n%d\n", ansx, ansy);
		for (i=0; i


你可能感兴趣的:(搜索,ACM)