当前位置: 首页 > news >正文

南京马鞍山网站建设国内旅行做行程网站

南京马鞍山网站建设,国内旅行做行程网站,照片做视频ppt模板下载网站好,网站建设 互成网络题目描述 由数字 0 0 0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字 1 1 1 构成,围圈时只走上下左右 4 4 4 个方向。现要求把闭合圈内的所有空间都填写成 2 2 2。例如: 6 6 6\times 6 66 的方阵( n 6 n6 n6&…

题目描述

由数字 0 0 0 组成的方阵中,有一任意形状闭合圈,闭合圈由数字 1 1 1 构成,围圈时只走上下左右 4 4 4 个方向。现要求把闭合圈内的所有空间都填写成 2 2 2。例如: 6 × 6 6\times 6 6×6 的方阵( n = 6 n=6 n=6),涂色前和涂色后的方阵如下:

0 0 0 0 0 0
0 0 1 1 1 1
0 1 1 0 0 1
1 1 0 0 0 1
1 0 0 0 0 1
1 1 1 1 1 1
0 0 0 0 0 0
0 0 1 1 1 1
0 1 1 2 2 1
1 1 2 2 2 1
1 2 2 2 2 1
1 1 1 1 1 1

输入格式

每组测试数据第一行一个整数 n ( 1 ≤ n ≤ 30 ) n(1 \le n \le 30) n(1n30)

接下来 n n n 行,由 0 0 0 1 1 1 组成的 n × n n \times n n×n 的方阵。

方阵内只有一个闭合圈,圈内至少有一个 0 0 0

输出格式

已经填好数字 2 2 2 的完整方阵。

样例 #1

样例输入 #1

6
0 0 0 0 0 0
0 0 1 1 1 1
0 1 1 0 0 1
1 1 0 0 0 1
1 0 0 0 0 1
1 1 1 1 1 1

样例输出 #1

0 0 0 0 0 0
0 0 1 1 1 1
0 1 1 2 2 1
1 1 2 2 2 1
1 2 2 2 2 1
1 1 1 1 1 1

提示

对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 30 1 \le n \le 30 1n30

一、错误分析

题意就是把被1包围的0改成2。
那么只需要找到包围起来的第一个0的坐标,就可以把所有被包围的0改成2。
第一个0的坐标是第一个1的右下角?
那么就有了下面错误的代码,WA了一个测试点

//错误代码
#include <iostream>
#include <queue>
using namespace std;
int n;
int dir[][2] = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};
int a[33][33];
struct node
{int x, y;
};
int main()
{cin >> n;int sx = 0, sy = 0;for (int i = 1; i <= n; i++)for (int j = 1; j <= n; j++){cin >> a[i][j];if (a[i][j] == 1 && sx == 0){sx = i, sy = j;}}sx++;sy++;// bfs广度优先queue<node> q;q.push({sx, sy});while (!q.empty()){node p = q.front();q.pop();for (int i = 0; i < 4; i++){int nx = p.x + dir[i][0], ny = p.y + dir[i][1];if (!(nx>n||ny>n||nx<1||ny<1)&&a[nx][ny] == 0){q.push({nx, ny});a[nx][ny] = 2;}}}for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){cout << a[i][j] << " ";}cout << endl;}
}

那么当墙有厚度的时候,这种找0的方法是错误的。
比如下面这组测试数据。

6 
1 1 1 1 1 1 
1 0 0 0 0 0 
1 1 1 1 1 1 
1 1 0 0 1 1 
1 1 0 0 1 1 
1 1 1 1 1 1 

二、正确分析

先将二维数组初始化为2,将有1的地方改为1,那么被1包围之外的2就是连续的了,只需要使用dfs或bfs就能够把所有包围之外的2改为0。
二维数组需要往外扩展一圈,这样就能保证包围之外的2是连续的。
如[1,n]的区间拓展为[0,n+1].

方法1.DFS

#include <iostream>
#include <queue>
using namespace std;
int n;
int dir[][2] = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};
int a[35][35];
struct node
{int x, y;
};
void dfs(int x,int y)
{if(x>n+1||y>n+1||x<0||y<0) return ;if(a[x][y] == 1||a[x][y]==0) return;a[x][y]=0;for (int i = 0; i < 4; i++){dfs(x + dir[i][0],y + dir[i][1]);}
}
int main()
{for(int i=0;i<33;i++)for(int j=0;j<33;j++){a[i][j]=2;}cin >> n;for (int i = 1; i <= n; i++)for (int j = 1; j <= n; j++){int t;cin >> t;if(t==1) a[i][j]=1;}dfs(0,0);for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){cout << a[i][j] << " ";}cout << endl;}
}

方法2.BFS

#include <iostream>
#include <queue>
using namespace std;
int n;
int dir[][2] = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};
int a[35][35];
struct node
{int x, y;
};
int main()
{for(int i=0;i<33;i++)for(int j=0;j<33;j++){a[i][j]=2;}cin >> n;for (int i = 1; i <= n; i++)for (int j = 1; j <= n; j++){int t;cin >> t;if(t==1) a[i][j]=1;}queue<node> q;q.push({0, 0});while (!q.empty()){node p = q.front();q.pop();for (int i = 0; i < 4; i++){int nx = p.x + dir[i][0], ny = p.y + dir[i][1];if (!(nx>n+1||ny>n+1||nx<0||ny<0)&&a[nx][ny] == 2){q.push({nx, ny});a[nx][ny] = 0;}}}for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){cout << a[i][j] << " ";}cout << endl;}
}
http://www.yayakq.cn/news/978535/

相关文章:

  • 设计师查询网站如何用网站赚钱
  • 国外电商网站如何做icp备案泰州网站建设托管
  • 东莞营销网站建设服务酒店网站建设的构思
  • 常德网站建设wynet123wordpress is ssl
  • 拨号服务器做网站nat123易企秀h5页面怎么制作
  • 网站原型图是什么马尾网站建设
  • 网站建设方案书 百度文库宁波网站制作公司官网
  • 哈尔滨百度网站排名软件推广方法
  • 网站做下子压缩文件的链接网站制作 符合百度
  • 网站模板之家官网网站建设好之后怎么上传东西
  • 青岛建立网站电话常州住房和城乡建设局网站
  • 功能性的网站网页网站开发工具
  • 网站建设费用选择网络专业电商培训方案
  • 个人网站设计说明Wordpress 导航条样式
  • 网站推广营销效果注册公司取名字大全
  • 建设好学校网站开发邦平台
  • 酒店定房网站开发编程外包
  • 如何建立自己的博客网站家政服家政服务网站模板
  • 免费建网站软件下载河源网站建设工作室
  • 北海哪里做网站建设品牌营销策划推广
  • 网站安全认证去哪做花瓣网素材
  • 网站开发需求分析中性能需求饮水机企业网站模板
  • 备案网站内容说明扬州建设机械网站
  • 如何给网站做排名优化网站成功上线报道
  • 大型网站制作如何免费制作企业网站
  • 哪些网站可以做房产推广windows优化大师收费
  • 箱包 东莞网站建设wordpress 后台无法登录
  • 信金在线制作网站山西响应式网站平台
  • 微网站预览制作一个企业网站多少钱
  • 网站建设参考论文百度seo整站优化公司