[CF1105D]Kilani and the Game

[CF1105D]Kilani and the Game

题目大意:给出一个$n\times m(n,m\leqslant10^3)$的地图,有$k(k\leqslant9)$个玩家,第$i$个玩家速度为$s_i$。地图中$\#$代表障碍;$.$ 代表空地;数字代表是一名编号为此数字的玩家的城堡。每个玩家按编号轮流操作,每次操作把自己城堡周围$s_i$格内的空地变成自己城堡。直到没有玩家能操作为止。输出每名玩家城堡的个数。

题解:$bfs$,显然发现每个点只会扩展一次,用$k$个$queue$保存每个人的可扩展的城堡,模拟扩展即可,$s_i$可以每次扩展一格,扩展$s_i$次来解决。复杂度$O(nm)$

卡点:

 

C++ Code:

#include <algorithm>
#include <cctype>
#include <cstdio>
#include <queue>
#define maxn 1005
#define maxk 10
const int D[2][4] = {
    {1, 0, -1, 0}, {0, 1, 0, -1}};

struct Point {
	int x, y;
	Point() { }
	Point(int __x, int __y) : x(__x), y(__y) { }
} ;
std::queue<Point> q[maxk];

bool used[maxn][maxn], Continue[maxk];
int n, m, k, len[maxk], ans[maxk];

inline bool over_range(int x, int y) {
	return x < 1 || x > n || y < 1 || y > m || used[x][y];
}

int main() {
	scanf("%d%d%d", &n, &m, &k);
	for (int i = 0; i < k; ++i) scanf("%d", len + i);
	for (int i = 1; i <= n; ++i) {
		static char s[maxn];
		scanf("%s", s + 1);
		for (int j = 1; j <= m; ++j) if (s[j] != '.') {
			used[i][j] = true;
			if (isdigit(s[j])) {
				int pos = (s[j] & 15) - 1;
				++ans[pos];
				q[pos].push(Point(i, j));
			}
		}
	}
	for (int now = 0, num = k; num; now += 1 - k, now += now >> 31 & k) {
		static std::queue<Point> Q;
		std::queue<Point> &q = ::q[now];
		for (int Tim = len[now]; Tim; --Tim) {
			if (q.empty()) {
				num -= !Continue[now];
				Continue[now] = true;
				break;
			}
			while (!q.empty()) {
				Point u = q.front(); q.pop();
				for (int i = 0, x, y; i < 4; ++i) {
					x = u.x + D[0][i], y = u.y + D[1][i];
					if (!over_range(x, y)) {
						++ans[now];
						used[x][y] = true;
						Q.push(Point(x, y));
					}
				}
			}
			std::swap(q, Q);
		}
	}
	for (int i = 0; i < k; ++i) printf("%d ", ans[i]); puts("");
	return 0;
}

  

转载于:https://www.cnblogs.com/Memory-of-winter/p/10350986.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/101137.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • ssh-server配置文件参数PermitRootLogin介绍

    ssh-server配置文件参数PermitRootLogin介绍sshd_config是sshd的配置文件,其中PermitRootLogin可以限定root用户通过ssh的登录方式,如禁止登陆、禁止密码登录、仅允许密钥登陆和开放登陆,以下是对可选项的概括:参数类别是否允许ssh登陆登录方式交互shellyes允许没有限制没有限制without-password允许除密码以外没

  • Python安装失败_python第三方库安装失败

    Python安装失败_python第三方库安装失败详细内容相信很多刚开始入门Python的菜鸟们在安装python第三方库的时候,多多少少都会遇到一些安装失败的问题。下面,我将结合自身经验,分享一下在windows操作系统上此类问题的解决办法。一、清楚自己所安装的python版本(2.7或3.6,andmore);(推荐学习:Python视频教程)二、检查是否安装了pip,pip版本是否可以使用;三、网络是否正常;如果确认上面都没有问题的话,就…

  • linux学习(一个) 在unbuntu通过添加新的用户

    linux学习(一个) 在unbuntu通过添加新的用户

  • python激活码2021【2021最新】

    (python激活码2021)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.htmlMLZPB5EL5Q-eyJsaWN…

  • DEDECMS开启邮箱验证通知的解决方法

    DEDECMS开启邮箱验证通知的解决方法

  • ICMP协议详解

    ICMP协议详解ICMP协议详解ICMP协议是一个网络层协议。一个新搭建好的网络,往往需要先进行一个简单的测试,来验证网络是否畅通;但是IP协议并不提供可靠传输。如果丢包了,IP协议并不能通知传输层是否丢包以及丢包的原因。所以我们就需要一种协议来完成这样的功能–ICMP协议。ICMP协议的功能ICMP协议的功能主要有:1.确认IP包是否成功到达目标地址2.通知在发送过程中IP包被…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号