洛谷 P1141 01迷宫 (dfs解决)

2024-06-21 21:12
文章标签 解决 01 dfs 洛谷 迷宫 p1141

本文主要是介绍洛谷 P1141 01迷宫 (dfs解决),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

有一个仅由数字 0 与 1 组成的 n×n 格迷宫。若你位于一格 0 上,那么你可以移动到相邻 4 格中的某一格 1 上,同样若你位于一格 1 上,那么你可以移动到相邻 4 格中的某一格 0 上。

你的任务是:对于给定的迷宫,询问从某一格开始能移动到多少个格子(包含自身)。

输入格式

第一行为两个正整数 𝑛,𝑚。

下面 𝑛 行,每行 𝑛 个字符,字符只可能是 0 或者 1,字符之间没有空格。

接下来 𝑚 行,每行两个用空格分隔的正整数 𝑖,𝑗,对应了迷宫中第 𝑖 行第 𝑗 列的一个格子,询问从这一格开始能移动到多少格。

输出格式

𝑚 行,对于每个询问输出相应答案。

这道题最优解是并查集,把这些01分块每个坐标的块所能达到的最大面积就是该坐标的答案,这里我们讲讲用dfs如何解决这个问题:

首先他的条件是这个格子是0那你只能上下左右移动,并且下一个格子必须是1(反之相反),那么这个地方就是这道题的坑点了,如果没有这个限制,这个题基本就是dfs的模板题目了,那有了这个限制就需要一些小技巧:

我们发现迷宫都是01组成的,在c++程序中你会发现如果a = 1,那么!a = 0,那么可以利用这个点,在每次搜索是都传入上一个点迷宫的"!值",这样一来只用判断这个点是否与他相等即可,代码如下:

#include <bits/stdc++.h>
using namespace std;int b[1005][1005],arr[100005];
char s[1005][1005];
int n,m;void dfs(int i,int j,int k,int index){if(i < 0 || i >= n || j < 0 || j >= n || b[i][j] != -1 || k != s[i][j] - '0') return;b[i][j] = index;arr[index] ++;dfs(i - 1,j,!k,index);dfs(i + 1,j,!k,index);dfs(i,j - 1,!k,index);dfs(i,j + 1,!k,index);
}int main()
{cin >> n >> m;memset(b,-1,sizeof(b));for(int i=0;i<n;i++){cin >> s[i];}for(int i=0,x,y;i<m;i++){cin >> x >> y;x --, y --;if(b[x][y] == -1) dfs(x,y,s[x][y] - '0',i);else arr[i] = arr[b[x][y]];}for(int i=0;i<m;i++){cout << arr[i] << endl;}return 0;
}

加油

这篇关于洛谷 P1141 01迷宫 (dfs解决)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1082348

相关文章

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

解决JSONField、JsonProperty不生效的问题

《解决JSONField、JsonProperty不生效的问题》:本文主要介绍解决JSONField、JsonProperty不生效的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录jsONField、JsonProperty不生效javascript问题排查总结JSONField

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

RedisTemplate默认序列化方式显示中文乱码的解决

《RedisTemplate默认序列化方式显示中文乱码的解决》本文主要介绍了SpringDataRedis默认使用JdkSerializationRedisSerializer导致数据乱码,文中通过示... 目录1. 问题原因2. 解决方案3. 配置类示例4. 配置说明5. 使用示例6. 验证存储结果7.

Swagger在java中的运用及常见问题解决

《Swagger在java中的运用及常见问题解决》Swagger插件是一款深受Java开发者喜爱的工具,它在前后端分离的开发模式下发挥着重要作用,:本文主要介绍Swagger在java中的运用及常... 目录前言1. Swagger 的主要功能1.1 交互式 API 文档1.2 客户端 SDK 生成1.3

java连接opcua的常见问题及解决方法

《java连接opcua的常见问题及解决方法》本文将使用EclipseMilo作为示例库,演示如何在Java中使用匿名、用户名密码以及证书加密三种方式连接到OPCUA服务器,若需要使用其他SDK,原理... 目录一、前言二、准备工作三、匿名方式连接3.1 匿名方式简介3.2 示例代码四、用户名密码方式连接4

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复