首页 > 其他分享 >P1162 填涂颜色题解

P1162 填涂颜色题解

时间:2024-02-17 21:13:08浏览次数:23  
标签:填涂 int 题解 vis P1162 vx vy dt include

【问题分析】

  • 分析题目可得此问题为连通块问题
  • 因此题枚举被包围的‘0’较难
  • 所以可用枚举每一个不被包围的‘0’

【设计程序】

#include<bits/stdc++.h>
#include<iostream>
#include<stdio.h>
#include<cstdio>
#include<queue>
using namespace std;
const int N = 30 + 5;
int n, d[N][N];
bool vis[N][N]; 
int dt[4][2] = {{-1, 0}, {0, 1}, {1, 0}, {0, -1}};
//四种扩展方法

void dfs (int x, int y)//描述点的位置
{
	vis[x][y] = 1;//标记为未包围
	for (int i = 0;i < 4; i++)
	{
		int vx, vy;
		vx = x + dt[i][0];
		vy = y + dt[i][1];
		if (vx < 1 || vx > n || vy < 1 || vy > n)	continue;
        	//不符合的跳过
		if (vis[vx][vy] || d[vx][vy])	continue;
		//不符合的跳过
		dfs (vx, vy) ; 
	}
}
int main()
{
	int i, j;
	scanf ("%d", &n);
	for (int i = 1;i <= n; i++)
		for (int j = 1;j <= n; j++)
			scanf ("%d", &d[i][j]);
	for (int i = 1;i <= n; i++)
	//找到四个角上不被包围的‘0’并标记
	{
		if (!vis[1][i] && !d[1][i])	dfs(1, i);
		if (!vis[n][i] && !d[n][i])	dfs(n, i);
		if (!vis[i][1] && !d[i][1])	dfs(i, 1);
		if (!vis[i][n] && !d[i][n])	dfs(i, n);
	}

	for (int i = 1;i <= n; i++)	
	{
		for (int j = 1;j <= n; j++)
		{
			if (!vis[i][j] && !d[i][j])	printf ("2 ");
			//如果没被标记且原为‘0’用2代替
			else 	printf ("%d ", d[i][j]);
		}
		printf ("\n");
	}
	return 0;
}

【调试代码】
1.测试样例,
2.自测数据(边界值或特殊值)(搜索一般测试样例就行了)

完结撒花!!

标签:填涂,int,题解,vis,P1162,vx,vy,dt,include
From: https://www.cnblogs.com/Assassins-Creed/p/18018414

相关文章

  • P2249 【深基13.例1】查找题解
    【问题分析】本题有n个数(n>10^6)n很大,查找m个数(m≤10^5),数最大为(10^9)方法一:用顺序查找的话时间复杂度为:O(n*m)会超时,只能得部分分;方法二:用桶排时间复杂度为O(n)+O(m),但是因为数最大为(109)空间复杂度为:O(109);方法三:用二分查找,时间复杂度为:O(m*logn),空间复杂度为O(n)。综合以......
  • P8248 简单数列 题解
    首先,圈重点:$1\len\le500$所有元素在$1\sim4$之间任意连续的连续子串不相同只要输出一种答案即可于是我们可以得到的是:由第一点和第二点可以看出此题可以写搜索解决。由第三点我们可以得到一种剪枝方式,就是如果目前数字放入后会产生相同的连续的连续子串。由第四点......
  • P1380 T型骨牌 题解
    本题每个位置有$5$种可能,据题中$n,m$均小于五,所以可以用搜索直接过。上代码#include<cstdio>usingnamespacestd;boolmp[15][15];intn,m,ans;intdt[4][5][2]={{{-1,-1},{0,-1},{1,-1},{0,0},{0,1}},{{-1,0},{0,0},{1,-1},{1,0},{1,1}},{{0,......
  • P1686 挑战 题解
    本题就是要找到最短的捷径。注意事项:捷径必须是直线。要求捷径最短而非总路程最短。捷径不与原有的路重合既然在同一直线上,则该捷径的起点与终点的横坐标或纵坐标相等。要把横坐标或纵坐标相同的聚在一起只需要排个序即可。捷径最短的话(以横坐标相等举例),只需要以$x$为第......
  • P1541 [NOIP2010 提高组] 乌龟棋题解
    有两种方法,代码注释都很详细了直接上代码一:记忆化搜索#include<bits/stdc++.h>usingnamespacestd;intt[15];intn,m;inta[400];intmp[45][45][45][45];//mp[i][j][k][l]表示1号用i张,2号用j张,3号用k张,4号用l张的情况下,最多能拿多少分intdfs(intstep,intw)//step......
  • TopCoder SRM478C RandomApple 题解
    题意:有\(k\)种苹果和\(n\)个箱子,每个箱子中有一些苹果,先等概率选取\(n\)个箱子组成集合的非空子集,再从选出的苹果中随机选一个,问每种苹果被选中的概率是多少箱子\(i\)有\(a_{i,j}\)个第\(j\)种苹果,第\(i\)个箱子的总苹果数\(siz_i=\sum\limits_{j=1}^ka_{i,j}\),苹果总数\(sum=\su......
  • 无限酒店 题解
    题目链接由于间隔不变,对于下面\(3\)个操作,只需记录起始位置与间隔即可。对于无数人到达酒店:所有位置的起始点\(\times2\),间隔\(\times2\),新的团队起始点为\(1\),间隔为\(2\)。对于\(k\)个人到达酒店:所有点的起始点\(+k\),间隔不变,新的团队起始点为\(0\),间隔为\(1\)......
  • CF1365G Secure Password 题解
    Description本题是交互题。有一个固定的数组\(A\),同时通过数组\(A\)构造出数组\(P\),具体来讲,\(P_i\)是\(A\)中除\(A_i\)外的所有元素的按位或。你需要在最多\(13\)次询问中得到最后的\(P\)数组。\(2\leqn\leq1000\)。Solution首先有一个\(2\logn\)的是注......
  • 传纸条 题解
    题目描述小渊和小轩是好朋友也是同班同学,他们在一起总有谈不完的话题。一次素质拓展活动中,班上同学安排做成一个m行n列的矩阵,而小渊和小轩被安排在矩阵对角线的两端,因此,他们就无法直接交谈了。幸运的是,他们可以通过传纸条来进行交流。纸条要经由许多同学传到对方手里,小渊坐在矩阵......
  • 2024.2.17模拟赛T1题解
    先考虑\(q=(1...n)\)的情况:发现如果设\(divcnt(p)\)表示将\(p\)划分为极小值域连续段的个数,那满足\(divcnt(p)\gem\)的排列都是合法的。那现在要求出有多少个排列符合条件可以先算出长度为\(i\),\(divnct\)为\(1\)的排列个数,这可以用dp解决然后再背包一下,就能求......