Iverson_ @ 2022-08-22 16:14:06
#include<iostream>
using namespace std;
const int dx[4]={0,0,1,-1};
const int dy[4]={1,-1,0,0};
int n;
int a[35][35],b[35][35];
void dfs(int x,int y)
{
int i;
if (x<1||y>n||x<1||y>n||a[x][y]!=0) return;
a[x][y]=1;
for (i=0;i<4;i++) dfs(x+dx[i],y+dy[i]);
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cin>>b[i][j];
if(b[i][j]==0) a[i][j]==0;
else a[i][j]==2;
}
}
dfs(0,0);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(a[i][j]==0) cout<<"2"<<" ";
else cout<<b[i][j]<<" ";
}
cout<<endl;
}
return 0;
}
by _saltFish_ @ 2022-08-22 16:19:47
为什么你的 dfs 从 if (x<1||y>n||x<1||y>n||a[x][y]!=0) return;
来排除最外面这一圈?
by _saltFish_ @ 2022-08-22 16:20:40
建议自己想想这个 if
里面到底该写什么。
by __YLX @ 2022-08-22 16:32:45
main函数改成:
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cin>>b[i][j];
if(b[i][j]==0) a[i][j]==0;
else a[i][j]==2;
}
}
dfs(1,1);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(a[i][j]==0) cout<<"2"<<" ";
else cout<<b[i][j]<<" ";
}
cout<<endl;
}
return 0;
}
应该可以了。
by yuanjing @ 2022-08-22 16:34:37
还有就是输入b[i]
后的if(b[i][j]==0) a[i][j]==0;else a[i][j]==2;
两个a[i][j]
后各多打了一个等号。。。
by yuanjing @ 2022-08-22 16:37:16
@YangLX_2021
不能从(1,1)
开始吧
by Iverson_ @ 2022-08-22 16:39:22
@yuanjing orzorz
by Iverson_ @ 2022-08-22 16:39:37
@JR_ytxy orzorz
by _saltFish_ @ 2022-08-23 08:19:50
@Iverson_ 得从 if (x<1||y>n||x<1||y>n||a[x][y]!=0) return;
改成 if (x<0||y>n+1||x<0||y>n+1||a[x][y]!=0) return;
by _saltFish_ @ 2022-08-23 08:22:07
再按照 @yuanjing 说的改一下就应该没有问题了。