当前位置: 首页 > news >正文

1818:红与黑【解析】-------深度优先搜索

1818:红与黑

描述

有一间长方形的房子,地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上,只能向相邻的黑色瓷砖移动。请写一个程序,计算你总共能够到达多少块黑色的瓷砖。

输入

包括多个数据集合。每个数据集合的第一行是两个整数W和H,分别表示x方向和y方向瓷砖的数量。W和H都不超过20。在接下来的H行中,每行包括W个字符。每个字符表示一块瓷砖的颜色,规则如下
1)‘.’:黑色的瓷砖;
2)‘#’:红色的瓷砖;
3)‘@’:黑色的瓷砖,并且你站在这块瓷砖上。该字符在每个数据集合中唯一出现一次。
当在一行中读入的是两个零时,表示输入结束。
输出
对每个数据集合,分别输出一行,显示你从初始位置出发能到达的瓷砖数(记数时包括初始位置的瓷砖)。

样例输入

6 9 
....#. 
.....# 
...... 
...... 
...... 
...... 
...... 
#@...# 
.#..#. 
0 0

样例输出

45

【题目解析】

本题需要求“@”所在的连通块大小。从起点开始,利用洪水填充法,将同一个连通块的瓷砖全部标记。根据模板框架,先界定清楚几个细节:
1.状态:描述当前局面情况的数学表示,一般是位置信息、时间信息等。在本题中,利用两个整数(x,y)表示当前所在的位置,表示当前在第x行、第y列。我们通常使用行列坐标,而不是坐标轴的坐标,以便于跟二维数组的下标对应起来。根据题意,起始状态便是“@”所在的位置。
2.标记:利用二维数组 v i s [ x ] [ y ] = t r u e vis[x][y]=true vis[x][y]=true,表示当前点(x,y)已经被染色。vis初始为 f a l s e false false,表示所有的点没有被染色。

代码如下:

#include<bits/stdc++.h>
using namespace std;
char a[21][21];
int w,h,cnt;
bool vis[21][21];
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};void dfs(int x,int y){vis[x][y]=1;//当前点标记cnt++;for(int i=0;i<4;i++){int nx=x+dx[i];int ny=y+dy[i];if(nx<1||ny<1||nx>h||ny>w)continue;//出地图if(a[nx][ny]!='.')continue;//如果不是黑砖if(vis[nx][ny])continue;//已经在当前路径中dfs(nx,ny);}
}int main(){while(true){cin>>w>>h;if(!w&&!h)break;int sx=-1,sy=-1;for(int i=1;i<=h;i++){cin>>(a[i]+1);for(int j=1;j<=w;j++){if(a[i][j]=='@'){sx=i;sy=j;}}}if(sx==-1 && sy==-1){cout<<0<<endl;continue;}cnt=0;//多组数据需要把数组初始化memset(vis,false,sizeof(vis));dfs(sx,sy);cout<<cnt<<endl;}return 0;
}

在深度优先搜索的使用上还可以使用另外一种方式:

void dfs(int x,int y){for(int i=0;i<4;i++){int nx=x+dx[i];int ny=y+dy[i];if(nx<1||ny<1||nx>h||ny>w)continue;//出地图if(a[nx][ny]!='.')continue;if(vis[nx][ny])continue;//已经在当前路径中vis[nx][ny]=1;//标记cnt++;dfs(nx,ny);			        }
}

这种方式不会处理当前点的状态,使用原方式的main函数会缺少起始点的黑砖,所以需要对main函数进行修改。完整代码如下:

#include<bits/stdc++.h>
using namespace std;
char a[21][21];
int w,h,cnt;
bool vis[21][21];
int dx[]={0,0,1,-1};
int dy[]={1,-1,0,0};void dfs(int x,int y){for(int i=0;i<4;i++){int nx=x+dx[i];int ny=y+dy[i];if(nx<1||ny<1||nx>h||ny>w)continue;//出地图if(a[nx][ny]!='.')continue;if(vis[nx][ny])continue;//已经在当前路径中vis[nx][ny]=1;//标记cnt++;dfs(nx,ny);			        }
}int main(){while(true){cin>>w>>h;if(!w&&!h)break;int sx=-1,sy=-1;for(int i=1;i<=h;i++){cin>>(a[i]+1);for(int j=1;j<=w;j++){if(a[i][j]=='@'){sx=i;sy=j;cnt=1;//记录起始点的黑砖}}}if(sx==-1 && sy==-1){cout<<0<<endl;continue;}memset(vis,false,sizeof(vis));dfs(sx,sy);cout<<cnt<<endl;}return 0;
}

相关文章:

1818:红与黑【解析】-------深度优先搜索

1818:红与黑 描述 有一间长方形的房子&#xff0c;地上铺了红色、黑色两种颜色的正方形瓷砖。你站在其中一块黑色的瓷砖上&#xff0c;只能向相邻的黑色瓷砖移动。请写一个程序&#xff0c;计算你总共能够到达多少块黑色的瓷砖。 输入 包括多个数据集合。每个数据集合的第一行…...

实验三 Oracle数据库的创建和管理

&#x1f57a;作者&#xff1a; 主页 我的专栏C语言从0到1探秘C数据结构从0到1探秘Linux &#x1f618;欢迎关注&#xff1a;&#x1f44d;点赞&#x1f64c;收藏✍️留言 &#x1f3c7;码字不易&#xff0c;你的&#x1f44d;点赞&#x1f64c;收藏❤️关注对我真的很重要&…...

Mysql:重点且常用的 SQL 标签整理

目录 1 <resultMap> 标签 2 <sql> 标签 3 <where> 标签 4 <if> 标签 5 <trim> 标签 6 <foreach> 标签 7 <set> 标签 1 <resultMap> 标签 比如以下代码&#xff1a; <resultMap type"SysCollege" id&qu…...

云锁防火墙编译安装nginx-plugin模块

一般情况下&#xff0c;当用户安装云锁的时候&#xff0c;云锁会自动适配nginx版本&#xff0c;使用我们已经预编译好的包含云锁模块的nginx备份并替换掉您当前系统中使用的nginx。卸载时&#xff0c;会将系统原始nginx文件替换回来。因此&#xff0c;云锁可保护使用nginx搭建的…...

【服务器数据恢复】服务器迁移数据时lun数据丢失的数据恢复案例

服务器数据恢复环境&服务器故障&#xff1a; 一台安装Windows操作系统的服务器。工作人员在迁移该服务器中数据时突然无法读取数据&#xff0c;服务器管理界面出现报错。经过检查发现服务器中一个lun的数据丢失。 服务器数据恢复过程&#xff1a; 1、将故障服务器中所有磁盘…...

6.4.2转换文件

6.4.2转换文件 利用Swf2VideoConverter2可以很方便地将Flash动画(*.swf)转换为其它的视频格式。 1&#xff0e;单击“添加”按钮&#xff0c;在弹出的下拉菜单中选择“添加文件”&#xff0c;在弹出的“Open Swf Files(打开Swf文件)”窗口中选择swf文件(如&#xff1a;那些花…...

智能驾驶新浪潮:SSD与UFS存储技术如何破浪前行?-UFS篇

如果说SSD是赛道上的超级跑车&#xff0c;那UFS更像是专为智能汽车定制的高性能轻量化赛车。UFS采用串行接口技术&#xff0c;像是闪电侠一样&#xff0c;将数据传输的速度推向新高&#xff0c;大幅缩短了系统启动时间和应用程序加载时间&#xff0c;这对追求即时反应的ADAS系统…...

TS 学习笔录(持续更新中)

TS学习笔录 1、TS 数据类型有哪些&#xff1f;2、元组是什么&#xff1f;3、union&#xff08;联合类型&#xff09;& Literal&#xff08;字面量类型&#xff09;?4、any 和 unknown 的区别&#xff1f;5、Object 对象类型&#xff1f;6、type 、interface 、 class 之间…...

RabbitMQ安装和使用

简介 RabbitMQ是一套开源&#xff08;MPL&#xff09;的消息队列服务软件&#xff0c;是由LShift提供的一个Advanced Message Queuing Protocol (AMQP) 的开源实现&#xff0c;由以高性能、健壮以及可伸缩性出名的Erlang写成。所有主要的编程语言均有与代理接口通讯的客户端库…...

使用pyechart创建折线图

import json from pyecharts.charts import Line from pyecharts import options# 首先使用文件打开数据 f_us open(Desktop/python/Project/数据可视化/美国.txt,r,encoding"UTF-8") f_rb open(Desktop/python/Project/数据可视化/日本.txt,r,encoding"UTF-8…...

Vue3+Ts:使用i18n实现国际化与全局动态下拉框框切换语言

Vue3Ts&#xff1a;使用i18n实现国际化与全局动态下拉框框切换语言 一、下载依赖&#xff1a;二、创建ts文件并配置main.ts三&#xff0c;如何使用1.在<template>中使用2.在setup中使用 四、全局下拉框动态切换 一、下载依赖&#xff1a; npm install vue-i18nnex二、创…...

多目标优化中常用的差分进化算法DE【2】

# 多目标优化中常用的进化算法 1、链接一 2、链接二 #后续继续补充多目标的差分进化算法MODE的应用 此链接介绍很详细&#xff0c;此处用来分享学习&#xff0c;后续有问题会继续进行补充。 如果你觉得不错&#xff0c;佛系随缘打赏&#xff0c;感谢&#xff0c;你的支持是…...

游卡:OceanBase在游戏核心业务的规模化降本实践

从 2023 年 9 月测试 OceanBase&#xff0c;到如今 3 个核心业务应用 OceanBase&#xff0c;国内最早卡牌游戏研发者之一的游卡仅用了两个月。是什么原因让游卡放弃游戏行业通用的 MySQL方案&#xff0c;选择升级至 OceanBase&#xff1f;杭州游卡网络技术有限公司&#xff08;…...

LightDB - oracle_fdw 过滤条件下推增强【24.1】

LightDB - oracle_fdw 过滤条件下推增强【24.1】 1. 字符串比较下推1.1 示例 2. 隐式转换下推2.1 示例 3. nvl 和trim 下推3.1 示例 LightDB 在24.1版本对oracle_fdw 的where下推进行了增强&#xff0c;新增对如下两种情况进行下推&#xff1a; 字符串比较下推&#xff0c;如 …...

【计算机网络】HTTP协议以及简单的HTTP服务器实现

文章目录 一、HTTP协议1.认识URL2.urlencode和urldecode3.HTTP协议格式4.HTTP的方法5.HTTP的状态码6.HTTP常见Header7.重定向8.长连接9.会话保持10.基本工具 二、简单的HTTP服务器实现1.err.hpp2.log.hpp3.procotol.hpp4.Sock.hpp5.Util.hpp6.httpServer.hpp7.httpServer.cc8.总…...

04 SpringBoot整合Druid/MyBatis/事务/AOP+打包项目

整合Druid 项目结构&#xff1a; 引入依赖&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaL…...

C++程序编译时的_GLIBCXX_USE_CXX11_ABI参数的值选择,适配昇腾Transformer推理加速库与LLM推理模型库

目录 2024/1/19日更新确定已安装G编译测试程序获取宏值安装对应的Transformer LLM推理模型库和Transformer推理加速库小结 2024/1/19日更新 具体使用cxx11abi0 还是cxx11abi1 可通过python命令查询 import torch torch.compiled_with_cxx11_abi()若返回True 则使用 cxx11abi1…...

什么是站群服务器?

网站群服务器是管理多个网站的强大工具&#xff0c;可以帮助站长轻松管理和维护多个网站&#xff0c;提高网站运营效率。在本文中&#xff0c;我们将讨论站点组服务器的优势&#xff0c;以及为什么它是网站管理员不可或缺的工具。 介绍站群服务器 网站群服务器是一个集中管理…...

《WebKit 技术内幕》之四(3): 资源加载和网络栈

3. 网络栈 3.1 WebKit的网络设施 WebKit的资源加载其实是交由各个移植来实现的&#xff0c;所以WebCore其实并没有什么特别的基础设施&#xff0c;每个移植的网络实现是非常不一样的。 从WebKit的代码结构中可以看出&#xff0c;网络部分代码的确比较少的&#xff0c;它们都在…...

vue3-模板引用

//1.调用ref函数 -> ref对象 const h1Ref ref(null) const comRef ref(null) //组件挂载完毕之后才能获取 onMounted(()>{console.log(h1Ref.value);console.log(comRef.value); })<div class"father"><!-- 通过ref标识绑定ref对象 --><h2 re…...

从单机到联网:手把手教你用NetCA为Oracle数据库配置‘电话线’(监听程序与本地网络服务)

从单机到联网&#xff1a;手把手教你用NetCA为Oracle数据库配置‘电话线’ 想象一下&#xff0c;你刚搬进一栋新公寓&#xff0c;已经熟悉了家里的水电开关&#xff08;本地Oracle安装&#xff09;&#xff0c;但还没登记电话号码&#xff08;监听程序&#xff09;和录入邻居联…...

Linux包管理核心:yum机制详解与实战配置指南

1. 项目概述&#xff1a;为什么你需要掌握yum&#xff1f;在Linux的世界里&#xff0c;尤其是以Red Hat、CentOS、Fedora为代表的发行版中&#xff0c;yum&#xff08;Yellowdog Updater, Modified&#xff09;是每一位系统管理员和开发者绕不开的核心工具。你可以把它想象成一…...

Grok 4.3与未来展望——智能体时代的Grok与AI安全新范式

目录1 Grok 4.3 Beta&#xff1a;最新版本的技术跃迁1.1 2026年4月&#xff1a;Grok 4.3的发布1.2 Computer Use&#xff1a;AI操作计算机的新范式2 reasoning_effort参数的深度解析2.1 推理资源的动态分配2.2 推理深度与质量的实证关系3 Grok的AI安全框架3.1 "最大真实性…...

手把手教你改造10块钱的USBASP烧录器,让它兼容Arduino IDE和AVRDUDESS

10元USBASP烧录器改造实战&#xff1a;解锁Arduino与AVRDUDESS全兼容方案 从闲置到全能&#xff1a;低成本硬件改造的价值探索 在电子制作和嵌入式开发领域&#xff0c;专业烧录工具往往价格不菲。但你可能不知道&#xff0c;手头那台吃灰的"智峰"版USBASP烧录器&…...

为什么你的Perplexity查不到正确代码?——基于127个失败Query的日志审计报告(附修复清单)

更多请点击&#xff1a; https://codechina.net 第一章&#xff1a;为什么你的Perplexity查不到正确代码&#xff1f;——基于127个失败Query的日志审计报告&#xff08;附修复清单&#xff09; 我们对127条在Perplexity平台中返回空结果、过时答案或完全偏离编程意图的用户Qu…...

KNN和K-Means选错距离度量?详解闵可夫斯基距离中参数p的实战调优

KNN与K-Means距离度量实战&#xff1a;如何用闵可夫斯基距离参数p提升模型性能 当你在scikit-learn中第一次使用KNN分类器时&#xff0c;可能会注意到一个不起眼的参数p——它默认为2&#xff0c;代表使用欧氏距离。但鲜有人告诉你&#xff0c;这个参数的选择可能让你的模型准确…...

手把手教你为100ASK T113-S3核心板点亮SPI屏:设备树配置、内核编译到fb-test测试

手把手教你为100ASK T113-S3核心板点亮SPI屏&#xff1a;设备树配置、内核编译到fb-test测试 在嵌入式Linux开发中&#xff0c;驱动一块SPI接口的LCD屏幕是常见的硬件交互项目。本文将基于全志T113-S3平台和100ASK核心板&#xff0c;详细讲解如何从零开始驱动ILI9341 SPI屏幕。…...

终极音乐歌词获取指南:163MusicLyrics让你的每首歌都有完美字幕

终极音乐歌词获取指南&#xff1a;163MusicLyrics让你的每首歌都有完美字幕 【免费下载链接】163MusicLyrics 云音乐歌词获取处理工具【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 还在为音乐播放器缺少歌词而烦恼&#xff1f;…...

终极指南:5分钟搞定MASA模组全家桶中文汉化,告别英文困扰

终极指南&#xff1a;5分钟搞定MASA模组全家桶中文汉化&#xff0c;告别英文困扰 【免费下载链接】masa-mods-chinese 一个masa mods的汉化资源包 项目地址: https://gitcode.com/gh_mirrors/ma/masa-mods-chinese 还在为Minecraft技术模组的英文界面而头疼吗&#xff1…...

告别时序噩梦:Vivado的report_qor_suggestions从导出RQS到导入生效全流程避坑指南

告别时序噩梦&#xff1a;Vivado的report_qor_suggestions从导出RQS到导入生效全流程避坑指南 在FPGA设计流程中&#xff0c;时序收敛问题往往成为工程师的"最后一公里"难题。当设计复杂度达到一定规模时&#xff0c;传统的手动优化方式不仅效率低下&#xff0c;还可…...