1.一定要注意细节 经常有字母打错 找了好久BUG
2.理清思路
3.第二种方法中不明白为什么用ckeck代替if条件语句就错误,求广大网友指正
以下给出两个路径输出的方法
第一种是DFS递归调用
第二种方法是stack的使用
/*
优先队列
BUG
1.
在BFS里面可以输出step
return 返回到主函数后 输出乱码
2.
终点如果还有数字 不会加上终点的数字
3.
n.y
#include
#include
using namespace std;
struct node
{
int x,y,step;
friend bool operator<(node a,node b)
{
return a.step>b.step;
}
};
char map[105][105];
int hp[105][105];
int vis[105][105];
int n,m;
int stepp[4][2]= {1,0,-1,0,0,1,0,-1}; //下上右左
int minn;
int time;
int flag;
int pre[105][105];
bool check(int x,int y)
{
if(x<0||y<0||x>=n||y>=m)//越界
return false;
if(map[x][y]=='X')//墙
return false;
if(vis[x][y]==true)//走过了
return false;
return true;
}
void BFS()
{
int bx,by;
priority_queue q;
node a,b;
a.x=0;
a.y=0;
a.step=0;
memset(vis,0,sizeof(vis));
vis[0][0]=1;
q.push(a);
while(!q.empty())
{
a=q.top();
q.pop();
//printf("%d %d %d\n",a.x,a.y,a.step);
if(a.x == n-1 && a.y == m-1)
{
flag=1;
minn=a.step;
return ;
}
for(int i=0; i<4; i++)
{
b.x=a.x+stepp[i][0];
b.y=a.y+stepp[i][1];
//if(check(bx,by))//如果能走
if(check(b.x,b.y))
{
//b.y(%d,%d)\n",time++,nx,ny,x,y);
while(hp[x][y]--)
{
printf("%ds:FIGHT AT (%d,%d)\n",time++,x,y);
}
}
int main(void)
{
while(~scanf("%d%d",&n,&m))
{
memset(pre,0,sizeof(pre));
for(int i=0; i
第二种:
#include
#include
#include
#include
#include
using namespace std;
struct node
{
int x;
int y;
int step;
friend bool operator<(node a,node b)
{
return a.step>b.step;
}
} a,b;
struct node1
{
int x;
int y;
int num;
} pre[105][105];
int hp[105][105];
int step[4][2]= {1,0,-1,0,0,1,0,-1};
int vis[105][105];
int m,n;
int minn;
char map[105][105];
int check(int x,int y)//用check就错误 不知道为什么
{
if(x=0&&y>=0&&y q;
int bx,by;
int vis[105][105];
memset(vis,0,sizeof(vis));
vis[0][0]=1;
a.x=0;
a.y=0;
a.step=0;
minn=0;
q.push(a);
while(!q.empty())
{
a=q.top();
// printf("%d %d %d \n",a.x,a.y,a.step);
q.pop();
if(a.x==x&&a.y==y)
{
minn=a.step;
return ;
}
for(int i=0; i<4; i++)
{
bx=a.x+step[i][0];
by=a.y+step[i][1];
if(bx>=0 && bx=0 && by Q;
node1 aa,bb;
bb.x=n-1;
bb.y=m-1;
bb.num=hp[n-1][m-1];//之前输入 bb.num=pre[n-1][m-1].pre;如果终点(n-1,m-1)的HP是1 bb.num是1, 而不是2 应该把 2传给bb.num(走到time+1 杀怪time+1)
Q.push(bb);
for(x1=n-1, y1=m-1;;)
{
x2=x1;
y2=y1;
Q.push(pre[x2][y2]);
x1=pre[x2][y2].x;
y1=pre[x2][y2].y;
if(x1==0&&y1==0)break;
}
while(!Q.empty())
{
if(Q.size()-1==0&&Q.top().num==1)//最后一个跳出条件
break;
aa=Q.top();
Q.pop();
if(Q.size()>0)
bb=Q.top();
if(aa.num==1)
printf("%ds:(%d,%d)->(%d,%d)\n",time++,aa.x,aa.y,bb.x,bb.y);
else
{
for(int i=1; i0)
printf("%ds:(%d,%d)->(%d,%d)\n",time++,aa.x,aa.y,bb.x,bb.y);
}
}
}
int main (void)
{
int x1,y1;
while(~scanf("%d%d",&n,&m))
{
for(int i=0; i