标签:ble cout 整数 初始 string cto can site []
题目链接http://noi.openjudge.cn/ch0205/6044/
佐助被大蛇丸诱骗走了,鸣人在多少时间内能追上他呢?
已知一张地图(以二维矩阵的形式表示)以及佐助和鸣人的位置。地图上的每个位置都可以走到,只不过有些位置上有大蛇丸的手下,需要先打败大蛇丸的手下才能到这些位置。鸣人有一定数量的查克拉,每一个单位的查克拉可以打败一个大蛇丸的手下。假设鸣人可以往上下左右四个方向移动,每移动一个距离需要花费1个单位时间,打败大蛇丸的手下不需要时间。如果鸣人查克拉消耗完了,则只可以走到没有大蛇丸手下的位置,不可以再移动到有大蛇丸手下的位置。佐助在此期间不移动,大蛇丸的手下也不移动。请问,鸣人要追上佐助最少需要花费多少时间?
样例输入1 4 4 1 #@## **## ###+ **** 样例输入2 4 4 2 #@## **## ###+ ****
样例输出1 6 样例输出2 4
查看
#include<cstdio> #include<cstdlib> #include<cstring> #include<iostream> #include<algorithm> #include<string> #include<vector> #define DEBUG(x) cout<<#x<<" = "<<x<<endl using namespace std; const int MAXN=210; const int INF=0x3f3f3f3f; int M,N,T; char Map[MAXN][MAXN]; int visited[MAXN][MAXN]; int steps[MAXN][MAXN][15]; int minStep=INF; int dirx[]={1,-1,0,0}; int diry[]={0,0,1,-1}; void dfs(int x,int y,int t,int step) {///位于x,y,已经走了step步 ///t表示剩余的查克拉,需要注意的是t必须在本次调用内更新 ///不能提前更新 // DEBUG(x); // DEBUG(y); // DEBUG(Map[x][y]); // DEBUG(t); // DEBUG(step); // printf("\n"); if(x<0||y<0||x>=M||y>=N||visited[x][y])return; if(t<0)return; if(step>=minStep)return; if(step>=steps[x][y][t])return; steps[x][y][t]=step; if(Map[x][y]==‘#‘)t--;/// if(Map[x][y]==‘+‘){ if(step<minStep)minStep=step; return; } visited[x][y]=1; for(int i=0;i<4 ;i++ ){ int xx=x+dirx[i]; int yy=y+diry[i]; //if(Map[xx][yy]==‘*‘)提前更新会导致状态的不一致性 dfs(xx,yy,t,step+1); //else //dfs(xx,yy,t-1,step+1); } visited[x][y]=0; } int main() { // freopen("in.txt","r",stdin); scanf("%d%d%d",&M,&N,&T); getchar(); int x,y; for(int i=0;i<M ;i++ ){ for(int j=0;j<N ;j++ ){ scanf("%c",&Map[i][j]); if(Map[i][j]==‘@‘){ x=i,y=j; } } getchar(); } memset(steps,0x3f,sizeof(steps)); dfs(x,y,T,0); if(minStep!=INF)printf("%d\n",minStep); else puts("-1"); }
标签:ble cout 整数 初始 string cto can site []
原文地址:https://www.cnblogs.com/MalcolmMeng/p/9246343.html