添加路障-蓝桥杯-DFS

在这里插入图片描述
自己另辟蹊径想的新思路 果然好像还是不太行呀

import java.util.Scanner;public class Main {static int T;//样例组数static int n;//矩阵大小static int[] X = {0,1,0,-1};static int[] Y = {1,0,-1,0};static int[] X1 = {1,0,-1,0};static int[] Y1 = {0,-1,0,1};static int flag = 0;public static void main(String[] args) {Scanner scan = new Scanner(System.in);T = scan.nextInt();while((T--)>0){n = scan.nextInt();char[][] arr = new char[n][n];int[][] vis = new int[n][n];for(int i = 0;i<n;i++){arr[i] =scan.next().toCharArray();}if(!dfs(0,0,vis,arr,n))//第一次就不通{System.out.println(0);}else{dfs1(0,0,vis,arr,n);//第二次标记int[][] vis1 = new int[n][n];if(dfs(0,0,vis1,arr,n)){System.out.println(2);}else{System.out.println(1);}}}}static boolean dfs(int x,int y,int[][] vis,char[][] arr,int n){if(arr[x][y] == 'C') return true;if(arr[x][y]!='A') vis[x][y] = 1;for(int i = 0;i<4;i++){int x1 = x + X[i];int y1 = y + Y[i];if(x1>=0&&x1<n&&y1>=0&&y1<n&&vis[x1][y1]==0&&arr[x1][y1]!='X'){if(dfs(x1,y1,vis,arr,n)) return true;}}return false;}static boolean dfs1(int x,int y,int[][] vis,char[][] arr,int n){if(arr[x][y] == 'C' ) return true;if(arr[x][y]!='A') vis[x][y] = 2;for(int i = 0;i<4;i++){int x1 = x + X1[i];int y1 = y + Y1[i];if(x1>=0&&x1<n&&y1>=0&&y1<n&&vis[x1][y1]==1&&arr[x1][y1]!='X'){arr[x1][y1] = 'X';return true;}if(x1>=0&&x1<n&&y1>=0&&y1<n&&vis[x1][y1]!=2&&arr[x1][y1]!='X'){if(dfs1(x1,y1,vis,arr,n)) return true;}}return false;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/732936.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSRF攻击解析:原理、防御与应对策略

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

激光在SIC晶圆制造中的应用

碳化硅是一种性能优异的第三代半导体材料&#xff0c;具有光学性能良好、化学惰性大、物理特性优良的特点&#xff0c;包括带隙宽、击穿电压高、热导率高和耐高温性能强等优点&#xff0c;常作为新一代高频、高功率器件的衬底材料&#xff0c;广泛应用在高端制造业领域&#xf…

UE4.27_ParticleSystem(没写完的材料)

UE4.27_ParticleSystem&#xff08;没写完的材料&#xff09; 参考实例&#xff1a; UE4[蓝图]下雪效果及雪的材质的实现

人工智能数学验证工具LEAN4【入门介绍9】高级乘法世界:逆否策略的等效替代,提取假设 的已知,tauto另类理解,更 严格的归纳法假设。。。

视频讲解&#xff1a;人工智能数学验证工具LEAN4【入门介绍9】高级乘法世界&#xff1a;逆否策略的等效替代&#xff0c;提取假设 的已知&#xff0c;tauto另类理解&#xff0c;更 严格的归纳法假设。。。_哔哩哔哩_bilibili import Game.Levels.AdvMultiplication.L08mul_eq_z…

vue element plus Text

文本的常见操作 基础用法# 由 type 属性来选择 Text 的类型。 DefaultPrimarySuccessInfoWarningDanger 尺寸# 使用 size 属性配置尺寸&#xff0c;可选的尺寸大小有: large, default 或 small LargeDefaultSmall 省略# 通过 truncated 属性&#xff0c;在文本超过视图或最大…

基于springboot+vue实现物资仓储物流管理系统项目【项目源码+论文说明】计算机毕业设计

基于springbootvue实现物资仓储物流管理系统演示 摘要 随着我国经济及产业化结构的持续升级&#xff0c;越来越多的企业借助信息化及互联网平台实现了技术的创新以及竞争力的提升&#xff0c;在电子经济的影响下仓储物流业务也获得了更多的关注度&#xff0c;利用系统平台实现…

《2024国家自然科学基金青年基金》 相关申请注意事项解读

一 年龄计算 2004 对应 89 2005 对应 90 2006 对应 91 2007 对应 92 2008 对应 93 2009 对应 94 2010 对应 95 .。。 二 资助比例&#xff08;2023&#xff09; 2024年 23.13% 2023年 24% 三 2024年政策变动&#xff0c;只能申请3年的30万&#xff0c;不能像23年一样选择10-20的…

简洁的链式思维(CCoT)提示

原文地址&#xff1a;Concise Chain-of-Thought (CCoT) Prompting 传统的CoT导致了输出令牌使用的增加&#xff0c;而CCoT提示是一种旨在减少LLM响应的冗长性和推理时间的提示工程技术。 2024 年 1 月 24 日 Areas where Chain-Of-Thought-like methodology has been introd…

猫头虎分享已解决Bug || 批处理错误:BatchJobFailure, ProcessingDelay

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

深入理解神经网络

图片怎么被识别的过程 (每层神经网络是数组,会对进来的数据进行加权求和[(weight*数据 然后累加) bias])(激活函数是为了训练weight和bias偏移值,在每个神经网络)(分类器会统计概率分类) 2. 引用链接 https://mp.weixin.qq.com/s?__bizMzIyNjMxOTY0NA&mid2247500124&…

RocketMQ-存储与弹性伸缩

存储与弹性伸缩 一、介绍二、存储架构图1.CommitLog2.ConsumeQueue3.IndexFile 三、消息读写流程1.写入流程1.1 获取Topic元数据1.2 消息投递1.3 消息写入 2.读取流程2.1 获取Topic元数据2.2 消息拉取2.3 消息消费 四、消息持久化1.页缓存2.刷盘2.1 同步刷盘2.2 异步刷盘 五、集…

全量知识系统中的翻译器以及百度文库AI应用中心给出的答复

Q1. 下面是全量知识系统中的翻译器的规划&#xff08;参考前一篇&#xff1a;全量知识系统 之 “百度翻译”。从“全量知识系统的翻译器”起。链接在下面&#xff09;。下面的文字分5次发出。链接&#xff1a; 全量知识系统 之 “百度翻译”-CSDN博客 第一次回答&#xff1a;…

解放自我,减轻负担:生活中的压力和痛苦源于自己

人生中&#xff0c;我们经常会感到压力重重&#xff0c;痛苦纠缠。然而&#xff0c;有没有想过&#xff0c;这些艰难困扰的根源究竟在哪里&#xff1f;或许&#xff0c;所有的压力都是因为我们太过迫切地追求某些东西&#xff0c;而所有的痛苦&#xff0c;则源于我们对事物过于…

【python】异常处理

前言 省略各种废话&#xff0c;直接快速整理知识点 try-except 基础 作用 程序不可能永远都是对的&#xff0c;当7除a&#xff0c;a由用户输入时&#xff0c;用户输入0就会报错。try-except就是解决这些问题。 结构 多分支自定义错误类型 上方的exception是一个错误类型…

遮蔽云和云雾函数

目录 简介源代码详细的函数说明.select&#xff08;&#xff09;cloudBitMask 1 << 10 -[操作符]qa.bitwiseAnd(cloudBitMask).eq(0).and&#xff08;&#xff09;image.updateMask().divide(10000) 函数应用 简介 这是一个在 Google Earth Engine 中用于遮蔽 Sentinel…

lambda有先后顺序

点击 QRadioButton 后 QLineEdit 收不到 textChanged 信号。 connect(radioButton, &QRadioButton::clicked, []{lineEdit->textChanged(""); });connect(lineEdit, &QLineEdit::textChanged, [](){... });QLineEdit 先 connect textCha…

基于Kronig-Penney能带模型的MATLAB求解与仿真

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 基于Kronig-Penney能带模型的MATLAB求解与仿真.综合利用 MATLAB提供的求解常微分方程、矩阵行列式、代数表达式化简及绘图等函数 ,可使 Kronig-Penney能带模型分析…

c语言,大宗撮合交易中心系统核心模块代码

撮合交易系统&#xff08;Matching System&#xff09;常用于大宗交易&#xff0c;如股票、期货等市场&#xff0c;它负责根据买卖双方的报价和数量&#xff0c;自动撮合成交。撮合系统的核心模块通常包括订单管理、价格计算和撮合逻辑等部分。 由于撮合系统的实现复杂且依赖于…

R语言更新版本

目录 一、更新R语言 1、安装最新的R语言版本 2、移动之前安装的packages 3、将Rstudio连接到最新的R语言 二、Rstudio更新 一、更新R语言 1、安装最新的R语言版本 查看当前R语言版本&#xff1a; R.version.string 下载最新的R语言安装包&#xff1a;R: The R Project…

C++面试题和笔试题(二)

1.什么是C中的RAII&#xff1f; RAII&#xff0c;全称Resource Acquisition Is Initialization&#xff0c;是C中的一种编程技巧。其核心思想是在对象的构造函数中获取资源&#xff0c;在析构函数中释放资源&#xff0c;以确保资源的正确管理。通过这种方式&#xff0c;资源的…