大犇们救命啊啊啊!!!
  • 板块P1238 走迷宫
  • 楼主yaolijun
  • 当前回复0
  • 已保存回复0
  • 发布时间2021/4/18 21:12
  • 上次更新2023/11/5 00:21:54
查看原帖
大犇们救命啊啊啊!!!
390290
yaolijun楼主2021/4/18 21:12

为什么我的DFS用了之后会重复输出数据啊啊啊!!! 请求帮助!!!```c


#include<bits/stdc++.h>
using namespace std;
int n,m,a[20][20],sx,sy,fx,fy,num=1,js,lc[50000][2];
bool bj[20][20];
int wx[4]={0,1,0,1},wy[4]={-1,0,1,0};
void print()
{
	js=1;
	for(int i=1;i<=num-1;i++)
	cout<<"("<<lc[i][0]<<","<<lc[i][1]<<")"<<"-"<<">";
	cout<<"("<<fx<<","<<fy<<")"<<endl;
}
void dfs(int x,int y)
{
	if(x==fx&&y==fy)
	{
		print();
		return;
	}
	for(int i=0;i<=3;i++)
	{
		int xx=x+wx[i];
		int yy=y+wy[i];
		if(bj[xx][yy]==0&&a[xx][yy]==1)
		{
			bj[x][y]=1;
			num++;
			lc[num][0]=xx;
			lc[num][1]=yy;
			dfs(xx,yy);
			bj[x][y]=0;
			num--;
		}
	}
}
int main()
{
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	for(int j=1;j<=m;j++)
	cin>>a[i][j];
	cin>>sx>>sy>>fx>>fy;
	lc[1][0]=sx;
	lc[1][1]=sy;
	dfs(sx,sy);
	if(js==0)
	cout<<"-1";
	return 0;
}
2021/4/18 21:12
加载中...