LxSmill @ 2023-02-17 21:33:15
#include<bits/stdc++.h>
using namespace std;
int n;
char a[100][100],b[100][100]={0};
void search(int x,int y)
{
if(a[x][y]!=0||x>n||x<1||y>n||y<1) return;
a[x][y]=1;
search(x+1,y);
search(x-1,y);
search(x,y+1);
search(x,y-1);
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
cin>>a[i][j];
if(a[i][j]==1) b[i][j]==-1;
}
for(int i=1;i<n;i++) search(1,i);
for(int i=1;i<n;i++) search(i,1);
for(int i=1;i<n;i++) search(n,i);
for(int i=1;i<n;i++) search(i,n);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(b[i][j]==-1) cout<<1<<' ';
if(a[i][j]==0) cout<<2<<' ';
else cout<<0<<' ';
}
cout<<endl;
}
return 0;
}
by QAQ_YTH @ 2023-02-17 22:10:51
这道题的标签是BFS
不太适合用DFS
做
可以参考一下P1506 拯救oibh总部
这题这样写:
#include<bits/stdc++.h>
using namespace std;
struct data{
int x,y;
};
queue<data>q;
int n,a[1001][1001];
bool vis[1001][1001];
void bfs(int x,int y){
vis[x][y]=1;
q.push({x,y});
while(!q.empty()){
int w=q.front().x,e=q.front().y;
q.pop();
if(a[w+1][e]==0 && w!=n && !vis[w+1][e]){
vis[w+1][e]=1;
q.push({w+1,e});
}
if(a[w-1][e]==0 && w!=1 && !vis[w-1][e]){
vis[w-1][e]=1;
q.push({w-1,e});
}
if(a[w][e-1]==0 && e!=1 && !vis[w][e-1]){
vis[w][e-1]=1;
q.push({w,e-1});
}
if(a[w][e+1]==0 && e!=n && !vis[w][e+1]){
vis[w][e+1]=1;
q.push({w,e+1});
}
}
}
int main(){
cin>>n;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cin>>a[i][j];
if(a[i][j]==1)vis[i][j]=1;
}
}
for(int i=1;i<=n;i+=n-1){
for(int j=1;j<=n;j++){
if(vis[i][j])continue;
bfs(i,j);
}
}
for(int i=1;i<=n;i+=n-1){
for(int j=1;j<=n;j++){
if(vis[j][i])continue;
bfs(j,i);
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(vis[i][j]==0)cout<<"2 ";
else cout<<a[i][j]<<' ';
}
cout<<'\n';
}
return 0;
}
by QAQ_YTH @ 2023-02-17 22:33:22
或者看看题解学学别的大神的做法,也可以做出来。洛谷的题都有一些详细的题解,相信像我这样的蒟蒻也都能看懂的
by _Mikasa @ 2023-03-01 20:06:39
@LxSmill 这是我这道题的深搜代码 希望可以帮到你
#include <bits/stdc++.h>
using namespace std;
int a[35][35],vist[35][35];
long long n;
void dfs(int i,int j){
if(i<0||j<0||i>n+1||j>n+1||vist[i][j]!=0){
return;
}
vist[i][j]=1;
dfs(i-1,j);
dfs(i+1,j);
dfs(i,j+1);
dfs(i,j-1);
}
int main(){
cin>>n;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cin>>a[i][j];
if(a[i][j]==0){
vist[i][j]=0;
}else{
vist[i][j]=2;
}
}
}
dfs(0,0);
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(vist[i][j]==0){
cout<<"2"<<" ";
}else{
cout<<a[i][j]<<" ";
}
}
cout<<endl;
}
return 0;
}