红与黑

有一个矩形房间,覆盖正方形瓷砖。每块瓷砖涂成了红色或黑色。一名男子站在黑色的瓷砖上,由此出发,可以移到四个相邻瓷砖之一,但他不能移动到红砖上,只能移动到黑砖上。编写一个程序,计算他通过重复上述移动所能经过的黑砖数(一开始站立的黑砖也要算)。

输入

开头行包含两个正整数W和H,W和H分别表示矩形房间的列数和行数,且都不超过20.
每个数据集有H行,其中每行包含W个字符。每个字符的含义如下所示:

'.'——黑砖
'#'——红砖
'@'——男子(仅出现一次)

输出

程序应该输出一行,包含男子从初始瓷砖出发可到达的瓷砖数

样例输入

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

样例输出

45



#include <bits/stdc++.h>
using namespace std;
char mapp[21][21];
int r,c,vis[21][21],cnt;
int a[4]={1,0,-1,0};
int b[4]={0,1,0,-1}; 
struct xyint
{
	int x,y;
}s;
queue<xyint> q;

void bfs()
{
	xyint now,nextt;
	q.push(s);
	while(q.size())
	{
		now=q.front();
		q.pop();
		if(!(now.x>=0&&now.x<r&&now.y>=0&&now.y<c)) break;
		for(int i=0;i<4;i++)
		{
			nextt.x = now.x+a[i], nextt.y = now.y+b[i];
			if(!vis[nextt.x][nextt.y] && mapp[nextt.x][nextt.y]=='.' && nextt.x>=0 && nextt.x<r && nextt.y>=0 && nextt.y<c)
			{
				cnt++;
				vis[nextt.x][nextt.y]=1;
				q.push(nextt);
			}
		} 
	}
}

int main()
{

	cin >> c >> r;
	cnt=1;
	for(int i=0;i<r;i++)
	{
		for(int j=0;j<c;j++)
		{
			cin >> mapp[i][j];
			if(mapp[i][j]=='@')
			{
				s.x=i;
				s.y=j;
			}
		}
	}
	bfs();
	cout<<cnt;
	return 0;
}

原文链接:https://www.cnblogs.com/momotrace/p/red-and-black.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:红与黑 - Python技术站

(0)
上一篇 2023年5月23日
下一篇 2023年4月25日

相关文章

  • Qt学习之容器类的使用教程详解

    Qt学习之容器类的使用教程详解 介绍 Qt框架提供了许多容器类来帮助开发者高效地管理数据集合。这些容器类提供了各种重载的方法和运算符来满足不同的需求。 本文将详细介绍Qt提供的常用容器类的使用方法和注意事项。 QVector 概述 QVector是Qt提供的动态数组容器类,可以在运行时根据需要自动扩展容量,并且可以方便地访问和修改其中的元素。 常用方法 QV…

    C 2023年5月23日
    00
  • 华为揽阅M2平板电脑做工怎么样?华为揽阅M2 10.0指纹平板拆机全过程图解

    华为揽阅M2是一款高性能的平板电脑,其外观和内部设计都十分精细,以下是关于此设备做工的详细分析以及拆机攻略。 华为揽阅M2平板电脑做工分析 外观设计 华为揽阅M2采用了一块10.1英寸的IPS触控屏幕,屏幕分辨率为1920*1200像素,支持10点触控和电磁笔输入。整个设备的外观采用了金属材质,手感舒适,整机重量为约500克。 在机身的四周布置了一些按钮、接…

    C 2023年5月22日
    00
  • C/C++语言中结构体的内存分配小例子

    下面是关于C/C++语言中结构体的内存分配小例子的完整攻略。 一、结构体的定义 定义结构体时,需要使用struct关键字。以下是一个结构体的示例代码: struct student{ int id; char name[30]; int age; }; 上述代码定义了一个名为student的结构体,其中包含三个成员变量:id、name和age。 二、结构体的…

    C 2023年5月23日
    00
  • win10下VSCode+CMake+Clang+GCC环境搭建教程图解

    以下是“win10下VSCode+CMake+Clang+GCC环境搭建教程图解”的完整攻略。 简介 Visual Studio Code是一款非常流行的开源跨平台代码编辑器。而CMake、Clang和GCC则是C/C++开发中用到的重要工具和库,它们能够优化代码编译、调试等方面的问题。在win10系统下配置VS Code+CMake+Clang+GCC环境…

    C 2023年5月23日
    00
  • C语言如何实现Unix时间戳与本地时间转化

    C语言提供了一些标准库函数,可以用来实现Unix时间戳与本地时间的转换。下面是实现这个功能的完整攻略: 获取Unix时间戳 Unix时间戳是指从1970年1月1日开始经过的秒数。在C语言中,可以使用time()函数获取当前的Unix时间戳。time()函数的定义如下: #include <time.h> time_t time(time_t *t…

    C 2023年5月23日
    00
  • 在ASP.NET 2.0中操作数据之三十八:处理BLL和DAL的异常

    在ASP.NET 2.0中操作数据之三十八:处理BLL和DAL的异常是一个重要的主题,对于开发者很有帮助。在开发应用程序时,处理异常是一个必要的过程,可以帮助我们检测和修复代码中的错误,提高程序的健壮性和可靠性。 异常处理的重要性 在应用程序开发中,异常处理非常重要。当应用程序发生异常,如果没有进行任何处理,程序将会停止运行,给用户带来极不好的使用体验。此时…

    C 2023年5月23日
    00
  • 使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇

    关于“使用jQuery向ASP.NET MVC传递复杂JSON数据-ModelBinder篇”的完整攻略可以分为以下几个步骤: 1. 创建MVC项目 在开始使用jQuery向ASP.NET MVC传递复杂JSON数据-ModelBinder篇的攻略前,首先需要创建一个MVC项目,可以使用Visual Studio创建。在创建MVC项目时需要选择ASP.NET…

    C 2023年5月23日
    00
  • C语言中的socket编程实例代码

    当我们需要在计算机程序中实现网络通信时,Socket 编程成为了一种非常重要的方式。C 语言是一种经典的编程语言,通过 C 语言实现 Socket 编程也是非常常见的。在接下来的讲解中,我们将会提供一个 C 语言中的 Socket 编程实例代码的完整攻略,并且会给出两条示例说明,让大家更好地理解代码的运用。 什么是 Socket 编程? Socket 是一种…

    C 2023年5月22日
    00
合作推广
合作推广
分享本页
返回顶部