当前位置:网站首页>动规(16)-并查集基础题——格子游戏
动规(16)-并查集基础题——格子游戏
2022-08-04 12:13:00 【H_Cisco】
【问题描述】
Alice和Bob玩了一个古老的游戏:首先画一个n * n的点阵(下图n = 3) 接着,他们两个轮流在相邻的点之间画上红边和蓝边:
直到围成一个封闭的圈(面积不必为1)为止,“封圈”的那个人就是赢家。因为棋盘实在是太大了(n<= 200),他们的游戏实在是太长了!他们甚至在游戏中都不知道谁赢得了游戏。于是请你写一个程序,帮助他们计算他们是否结束了游戏?
【输入格式】
输入数据第一行为两个整数n和m。m表示一共画了m条线。以后m行,每行首先有两个数字(x,y),代表了画线的起点坐标,接着用空格隔开一个字符,假如字符是"D ",则是向下连一条边,如果是"R"就是向右连一条边。输入数据不会有重复的边且保证正确。
【输出格式】
输出一行:在第几步的时候结束。假如m步之后也没有结束,则输出一行“draw”。
【输入样例】
3 5
1 1 D
1 1 R
1 2 D
2 1 R
2 2 D
【输出样例】
4
#include <cstdio>
#include <iostream>
using namespace std;
int fa[40001], n, m, x, y, r1, r2, xx, yy;
char ch;
int find(int u)
{
return fa[u] == u ? u : fa[u] = find(fa[u]);
}
int read()
{
int x = 0;
char ch = getchar();
while (!isdigit(ch))
ch = getchar();
while (isdigit(ch))
x = x * 10 + ch - 48, ch = getchar();
return x;
}
int main()
{
cin >> n >> m;
for (int i = 1; i <= n * n; i++)
fa[i] = i;
for (int i = 1; i <= m; i++)
{
x = read();
y = read();
cin >> ch;
xx = n * (x - 1) + y;
if (ch == 'D')
yy = xx + n;
else
yy = xx + 1;
r1 = find(xx);
r2 = find(yy);
if (r1 != r2)
fa[r1] = r2;
else
{
cout << i;
return 0;
}
}
cout << "draw" << endl;
return 0;
}
边栏推荐
- ESP8266-Arduino编程实例-MQ3酒精传感器驱动
- 国际原子能机构总干事警告称扎波罗热核电站安全形势已“完全失控”
- MySQL索引原理以及SQL优化
- 外置USB供电与内置锂电池供电自动切换电路
- 到底什么是JS原型
- 深度学习------pytorch实现cifar10数据集
- 从数学角度和编码角度解释 熵、交叉熵、KL散度
- MySQL必知必会(初级篇)
- 技术分享| 融合调度系统中的电子围栏功能说明
- Focusing on data sources, data quality and model performance to build a credit profile of small and micro enterprises
猜你喜欢
随机推荐
WPF---Grid布局讲解
ESP8266-Arduino编程实例-APDS-9930环境光和趋近感器驱动
数据库表列类型;DML_添加数据;DDL_修改,删除数据库表
DQL-查询操作
Flutter强大的下拉筛选菜单gzx_dropdown_menu
TPC藏宝计划IDO自由协议复利模式开发功能分析
涨姿势了!原来这才是多线程正确实现方式
UMA & Hong Kong Polytechnic & Ali propose SP-ViT to learn 2D space prior knowledge for visual Transformer!
防抖函数封装
动手学深度学习_LeNet
break与continue超详解!!!
剑指offer专项突击版第19天
树莓派入门
今天15:00 | CVPR 2022 论文分享精彩继续
*SEO*
微信公众号之底部菜单
开发小程序插件如何实现盈利?
全面认识MOS管,一篇文章就够了
【目标检测】------yolo:xml和txt文件相互转化
傅里叶级数与傅里叶变换学习