P1141 01迷宫 (搜索,dfs,bfs)
洛谷链接:https://www.luogu.com.cn/problem/P1141
P1141 01迷宫
题目描述
有一个仅由数字 \(0\) 与 \(1\) 组成的 \(n \times n\) 格迷宫。若你位于一格 \(0\) 上,那么你可以移动到相邻 \(4\) 格中的某一格 \(1\) 上,同样若你位于一格 \(1\) 上,那么你可以移动到相邻 \(4\) 格中的某一格 \(0\) 上。
你的任务是:对于给定的迷宫,询问从某一格开始能移动到多少个格子(包含自身)。
输入格式
第一行为两个正整数 \(n,m\)。
下面 \(n\) 行,每行 \(n\) 个字符,字符只可能是 \(0\) 或者 \(1\),字符之间没有空格。
接下来 \(m\) 行,每行两个用空格分隔的正整数 \(i,j\),对应了迷宫中第 \(i\) 行第 \(j\) 列的一个格子,询问从这一格开始能移动到多少格。
输出格式
\(m\) 行,对于每个询问输出相应答案。
输入输出样例 #1
输入 #1
2 2
01
10
1 1
2 2
输出 #1
4
4
说明/提示
对于样例,所有格子互相可达。
- 对于 \(20\%\) 的数据,\(n \leq 10\);
- 对于 \(40\%\) 的数据,\(n \leq 50\);
- 对于 \(50\%\) 的数据,\(m \leq 5\);
- 对于 \(60\%\) 的数据,\(n,m \leq 100\);
- 对于 \(100\%\) 的数据,\(1\le n \leq 1000\),\(1\le m \leq 100000\)。
思路:
使用dfs,创建$$ansn[N][N]$$数组,用来存储遍历过的点的答案,这样后面的点无须再次dfs,可以直接输出答案,从而不会TLE,
不难发现,第一次能够经历过的点相互之间一定是连通的,所以这些点的答案是一致的,而未遍历的点,我们后面如果遇到,再dfs,这样的话,所有点只需要遍历一次,大大降低了时间复杂度
#include <bits/stdc++.h>
using namespace std;
const int N=1e3+10;
typedef long long ll;
char b[N][N];
int n,m;
int ans;
bool vis[N][N];
int dirx[4]={0,1,-1,0};
int diry[4]={1,0,0,-1};
int ansn[N][N]={0};
vector<pair<int,int>>vec;
void dfs(int x,int y)
{
if(vis[x][y])return ;
vec.push_back(make_pair(x,y));
vis[x][y]=1;
ans++;
for(int i=0;i<4;i++)
{
int xx = x+dirx[i];
int yy = y+diry[i];
if(xx<0||xx>=n||yy<0||yy>=n)continue;
if(vis[xx][yy])continue;
if(b[x][y]!=b[xx][yy])dfs(xx,yy);
}
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin>>n>>m;
for(int i=0;i<n;i++)
{
string s;
cin>>s;
for(int j=0;j<n;j++)
{
b[i][j]=s[j];
}
}
for(int i=0;i<m;i++)
{
int x,y;
cin>>x>>y;
if(vis[x-1][y-1])
{
cout<<ansn[x-1][y-1]<<endl;
continue;
}
vec.clear();
ans = 0;
dfs(x-1,y-1);
for(auto pa:vec)
{
ansn[pa.first][pa.second]=ans;
}
cout<<ansn[x-1][y-1]<<endl;
}
return 0;
}
P1141 01迷宫 (搜索,dfs,bfs)的更多相关文章
- 洛谷P1141 01迷宫【DFS】
有一个仅由数字00与11组成的n \times nn×n格迷宫.若你位于一格0上,那么你可以移动到相邻44格中的某一格11上,同样若你位于一格1上,那么你可以移动到相邻44格中的某一格00上. 你的任 ...
- 洛谷——P1141 01迷宫
P1141 01迷宫 题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任 ...
- luogu P1141 01迷宫 x
P1141 01迷宫 题目描述 有一个仅由数字0与1组成的n×n格迷宫.若你位于一格0上,那么你可以移动到相邻4格中的某一格1上,同样若你位于一格1上,那么你可以移动到相邻4格中的某一格0上. 你的任 ...
- POJ 2243 简单搜索 (DFS BFS A*)
题目大意:国际象棋给你一个起点和一个终点,按骑士的走法,从起点到终点的最少移动多少次. 求最少明显用bfs,下面给出三种搜索算法程序: // BFS #include<cstdio> #i ...
- Luogu P1141 01迷宫【搜索/dfs】By cellur925
题目传送门 我tm到现在还需要刷这种水搜索...我退役吧. 但就是搜索弱嘛 补一补嘛qwq 题目大意:给你一张地图与许多询问,每次询问求这个点所在联通块的点的个数. 所以这个题目的本质就是在求联通块. ...
- P1141 01迷宫 DFS (用并查集优化)
题目描述 有一个仅由数字00与11组成的n \times nn×n格迷宫.若你位于一格0上,那么你可以移动到相邻44格中的某一格11上,同样若你位于一格1上,那么你可以移动到相邻44格中的某一格00上 ...
- 迷宫问题 dfs bfs 搜索
定义一个二维数组: int maze[5][5] = { 0, 1, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, ...
- P1141 01迷宫 dfs连通块
题目描述 有一个仅由数字000与111组成的n×nn \times nn×n格迷宫.若你位于一格0上,那么你可以移动到相邻444格中的某一格111上,同样若你位于一格1上,那么你可以移动到相邻444格 ...
- 洛谷P1141 01迷宫【bfs】
题目链接:https://www.luogu.org/problemnew/show/P1141 题意: 有一个填了0和1的n*n的格子,只能0走到1,1走到0 有m组询问(数据量是1e5),问某一个 ...
- 洛谷 - P1141 - 01迷宫 - dfs
https://www.luogu.org/problemnew/show/P1141 能互相到达的格子的答案自然是一样的,第一次dfs标记联通块,第二次dfs把cnt传递到整个联通卡并顺手消除vis ...
随机推荐
- 妙妙线段树+DFS序判断子孙节点,但似乎还可以树链剖分?(CF Div3 909 G)
G. Unusual Entertainment 原题链接:https://codeforces.com/contest/1899/problem/G 题目大意: 给定一棵树,根节点为1,给定一个\( ...
- 操作系统:设备I/O -- 如何表示设备类型与设备驱动?
计算机的结构 计算机结构示意图: 主板上的各种芯片并非独立存在,而是以总线为基础连接在一起的,各自完成自己的工作,又能相互打配合,共同实现用户要求的功能. 如何管理设备 前面的学习中宏,实现了管理内存 ...
- 逆序对计数问题之C#实现(O(nlogn))
逆序对计数问题是一个经典的算法问题,常见于计算机科学和数据结构领域.它的目标是计算数组中所有的逆序对的数量.逆序对是指数组中两个元素满足位置关系(i,j),且有 A[i]>A[j]. 它的应用有 ...
- Kafka King 推荐一款漂亮、现代、实用的kafka客户端
Kafka King 一个漂亮.现代.实用的kafka客户端,使用python flet.flutter构建. Github主页:https://github.com/Bronya0/Kafka-Ki ...
- 简单介绍List和数组转List集合
目录 综述 如何创建List 六种数组转List的方法 for循环遍历 Arrays.asList() new ArrayList<>(Arrays.asList(array)) Coll ...
- 通用jar包部署脚本
在<Linux下部署Spring Boot 项目 jar包>中,小编介绍了一步一步发布jar包的方法,这里提供一个通用Shell脚本,傻瓜式发布Spring Boot项目. 通过W ...
- linux安全基线自查手册
1.Redhat/CentOS 7.x配置模板 1.1 帐号管理 1.1.1 检查是否设置除root之外UID为0的用户 严重级别:中危 理论依据:任何UID为0的帐户都具有系统上的超级用户特权,只有 ...
- Manacher例题问题汇总
Manacher例题问题汇总 本篇随笔面向个人 本来以为回文串很简单,但是没有做对应的练习前下此定论为时过早. https://www.ybtoj.com.cn/contest/75 模板 虽然例题中 ...
- linux之whiptail交互式shell脚本对话框
简单说明 当你在linux环境下setup软件的时候就会有相应的对话框让你输入.虽然我们已经习惯了这种交互的方法,但是如果有一种直观的界面来输入是不是会更加友好和方便呢,在shell脚本中你可以使用- ...
- 使用Oracle数据库的递归查询语句生成菜单树
SQL 格式 SELECT * FROM TABLE WHERE [...结果过滤语句] START WITH [...递归开始条件] CONNECT BY PRIOR [...递归执行条件] 查询所 ...