HDU 4213-Sokoban

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4213

题意:

推箱子游戏

给你一张地图,按照指令是否能够将箱子都推到目标地点

思路:

直接模拟就好了。

不过,要注意一些地方:

(1)注意'B'和'b','W'和'w'的区别,例如下面的这组测试数据:


输出:


(2)若是执行到某一段指令时,已经将将箱子全部送到目标地点,后面的指令就不再执行了

例如这组测试数据:


输出:


#include<cstdio>
#include<cstring>
#define maxn 20
char map[maxn][maxn];
bool aim[maxn][maxn];//箱子要推到的地方
bool complete;//能否完成任务
int dirx[4]={-1,1,0,0},diry[4]={0,0,-1,1};//上下左右
int startx,starty;//起点
int n,m;//地图的长和宽
void run(char *s)
{
	for(;*s;s++)
	{
		//确定此时所走的方向
		int dir;
		if(*s=='U') dir=0;
		else if(*s=='D') dir=1;
		else if(*s=='L') dir=2;
		else dir=3;
		int tx=startx+dirx[dir],ty=starty+diry[dir];//下一步要走的地方
		if(map[tx][ty]!='#')
		{
			int nextx=tx+dirx[dir],nexty=ty+diry[dir];
			bool flag=false;
			//如果推的是箱子,那么,箱子后面就不能是箱子也不能是墙
			if(map[tx][ty]=='b'&&map[nextx][nexty]!='b'&&map[nextx][nexty]!='#')
			{
				map[tx][ty]='w';
				map[nextx][nexty]='b';
				map[startx][starty]='.';
				startx=tx,starty=ty;
				flag=true;
			}
			else if(map[tx][ty]=='.'||map[tx][ty]=='+')
			{
				map[tx][ty]='w';
				map[startx][starty]='.';
				startx=tx,starty=ty;
			}
			if(flag)
			{
				int t1=0,t2=0;
				for(int i=0;i<n;i++)
					for(int j=0;j<m;j++)
					{
						if(aim[i][j])
						{
							t1++;
							if(map[i][j]=='b')
								t2++;
						}
					}
				if(t1==t2)//已经成功把所有的箱子都推到目标
				{
					complete=true;
					return;
				}
			}
		}
	}
}
int main()
{
	int cas=1;
	while(scanf("%d %d",&n,&m),n||m)
	{
		int i,k;
		complete=false;
		for(i=0;i<n;i++)
			for(k=0;k<m;k++)
			{
				scanf(" %c",&map[i][k]);//不要写成scanf("%c",&map[i][k]);
				aim[i][k]=false;
				if(map[i][k]=='+'||map[i][k]=='B'||map[i][k]=='W')//这里最坑爹,要考虑到人在目标地点和箱子在目标地点的情况
				{
					aim[i][k]=true;
					if(map[i][k]!='+')
						map[i][k]+=32;
				}
				if(map[i][k]=='w')
					startx=i,starty=k;
			}
		char str[100];
		scanf("%s",str);
		run(str);
		printf("Game %d: ",cas++);
		puts(complete?"complete":"incomplete");
		for(i=0;i<n;i++)
		{
			for(k=0;k<m;k++)
			{
				if(aim[i][k])
				{
					if(map[i][k]=='b'||map[i][k]=='w')
						map[i][k]-=32;
					else
						map[i][k]='+';
				}
				printf("%c",map[i][k]);
			}
			printf("\n");
		}
    }
	return 0;
}

方案是为解决特定问题或达成特定目标而制定的一系列计划或步骤。它的作用是提供一种系统性的方法,以有效地应对挑战、优化流程或实现目标。以下是方案的主要作用: 问题解决: 方案的核心目标是解决问题。通过系统性的规划和执行,方案能够分析问题的根本原因,提供可行的解决方案,并引导实施过程,确保问题得到合理解决。 目标达成: 方案通常与明确的目标相关联,它提供了一种达成这些目标的计划。无论是企业战略、项目管理还是个人发展,方案的制定都有助于明确目标并提供达成目标的路径。 资源优化: 方案在设计时考虑了可用资源,以最大化其效用。通过明智的资源分配,方案可以在有限的资源条件下实现最大的效益,提高效率并减少浪费。 风险管理: 方案通常会对潜在的风险进行评估,并制定相应的风险管理策略。这有助于减轻潜在问题的影响,提高方案的可行性和可持续性。 决策支持: 方案提供了决策者所需的信息和数据,以便做出明智的决策。这种数据驱动的方法有助于减少不确定性,提高决策的准确性。 团队协作: 复杂的问题通常需要多个人的协同努力。方案提供了一个共同的框架,帮助团队成员理解各自的职责和任务,促进协作并确保整个团队朝着共同的目标努力。 监控与评估: 方案通常包括监控和评估的机制,以确保实施的有效性。通过定期的评估,可以及时调整方案,以适应变化的环境或新的挑战。 总体而言,方案的作用在于提供一种有序、有计划的方法,以解决问题、实现目标,并在实施过程中最大化资源利用和风险管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值