P1162 填涂颜色 java_bfs

2023-10-09 04:10
文章标签 java bfs 颜色 填涂 p1162

本文主要是介绍P1162 填涂颜色 java_bfs,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
在这里插入图片描述

分析

  1. 此题我们可以用bfs,题意就是把被1包围的部分改为2,故我们可以把1理解为墙,不能通过1往后搜索,通过vis数组去记录哪些点未被访问,最后我们可以通过map的值是否0加上是否访问过,即可确定吐的范围;
  2. 数组的周围加一个框,就是方阵的行、列有效范围是从1到n, 但我们从0,0开始搜索,可以避免遇到方阵的第一个点就是1,直接堵死了,无路可走;
  3. 关于四个方向走的问题,我们可以通过一个四层for循环加上x、y的偏移量数组去简化问题;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;public class Main {static int n;static int[][] vis = new int[35][35];static int[][] map = new int[35][35];static int[] dx = { -1, 0, 1, 0 };static int[] dy = { 0, 1, 0, -1 };static Queue<Integer> x = new LinkedList<>();static Queue<Integer> y = new LinkedList<>();static void bfs() {// 从0,0点开始搜索vis[0][0] = 1;x.offer(0);y.offer(0);while (!x.isEmpty()) {// 队列已经有的那个点0,0开始向四个方向搜索for (int k = 0; k < 4; k++) {int xx = x.peek() + dx[k];int yy = y.peek() + dy[k];if (xx >= 0 && yy >= 0 && xx <= n + 1 && yy <= n + 1 && vis[xx][yy] == 0 && map[xx][yy] == 0) {// 不能越界且,遇到1相当于墙,不能搜索他及其后面的x.offer(xx);y.offer(yy);vis[xx][yy] = 1;}}x.poll();y.poll();}}public static void main(String[] args) {Scanner sc = new Scanner(System.in);n = sc.nextInt();for (int i = 1; i <= n; i++) {// 数组外面套一圈0;for (int j = 1; j <= n; j++) {map[i][j] = sc.nextInt();}}bfs();// 最后没被遍历到的点且该点的值为0,就是被1包围住的点,即需要输出2for (int i = 1; i <= n; i++) {for (int j = 1; j <= n; j++) {if (map[i][j] == 0 && vis[i][j] == 0) {System.out.print(2 + " ");} else {System.out.print(map[i][j] + " ");}}System.out.println();}}
}

这篇关于P1162 填涂颜色 java_bfs的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法

《springboot整合阿里云百炼DeepSeek实现sse流式打印的操作方法》:本文主要介绍springboot整合阿里云百炼DeepSeek实现sse流式打印,本文给大家介绍的非常详细,对大... 目录1.开通阿里云百炼,获取到key2.新建SpringBoot项目3.工具类4.启动类5.测试类6.测

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll