Place the Robots 需要较强的建图能力
思路:在任意一个点格子放机器人,那么它所在的行和列被控制了。我们对每一行或每一列连续的空地(草地忽视)称之为块,给每一行和每一列的块标号,
每一行的快与每一列的快相交的话,才有只有一个交点。 我们把交点当边,把行块和列块连接起来。每一个空第都是一条边。详细细节见代码。
1 #include <iostream>
2 #include <cstdio>
3 #include <cstring>
4 #include <cmath>
5 #include <algorithm>
6 #include <string>
7 #include <vector>
8 #include <set>
9 #include <map>
10 #include <stack>
11 #include <queue>
12 #include <sstream>
13 #include <iomanip>
14 using namespace std;
15 typedef long long LL;
16 const int INF = 0x4fffffff;
17 const double EXP = 1e-5;
18 const int MS = 55;
19 const int SIZE = 100005;
20
21 // data struct
22 char pic[MS][MS];
23 int sx[MS][MS];
24 int sy[MS][MS];
25
26 int x[MS*MS];
27 int y[MS*MS];
28
29 int cx[MS*MS];
30 int cy[MS*MS];
31
32 bool edges[MS*MS][MS*MS];
33 int mark[MS*MS];
34 int nx,ny,kase;
35 int n,m;
36
37 int path(int u)
38 {
39 for(int v=1;v<=ny;v++)
40 {
41 if(edges[u][v]&&!mark[v])
42 {
43 mark[v]=1;
44 if(cy[v]==0||path(cy[v]))
45 {
46 cx[u]=v;
47 cy[v]=u;
48 return 1;
49 }
50 }
51 }
52 return 0;
53 }
54
55 void match()
56 {
57 memset(cx,0,sizeof(cx));
58 memset(cy,0,sizeof(cy));
59 int ans=0;
60 for(int u=1;u<=nx;u++)
61 {
62 if(!cx[u])
63 {
64 memset(mark,0,sizeof(mark));
65 ans+=path(u);
66 }
67 }
68 printf("Case :%d\n%d\n",kase++,ans);
69 }
70
71 int main()
72 {
73 kase=1;
74 int T;
75 scanf("%d",&T);
76 while(T--)
77 {
78 scanf("%d%d",&n,&m);
79 for(int i=0;i<n;i++)
80 scanf("%s",pic[i]);
81 memset(sx,0,sizeof(sx));
82 memset(sy,0,sizeof(sy));
83 int num=0,flag;
84 for(int i=0;i<n;i++)
85 {
86 flag=0;
87 for(int j=0;j<m;j++)
88 {
89 if(pic[i][j]=='o')
90 {
91 if(flag==0)
92 {
93 num++;
94 flag=1;
95 }
96 sx[i][j]=num;
97 }
98 else if(pic[i][j]=='#')
99 flag=0;
100 }
101 }
102 nx=num;
103 num=0;
104 for(int j=0;j<m;j++)
105 {
106 flag=0;
107 for(int i=0;i<n;i++)
108 {
109 if(pic[i][j]=='o')
110 {
111 if(flag==0)
112 {
113 num++;
114 flag=1;
115 }
116 sy[i][j]=num;
117 }
118 else if(pic[i][j]=='#')
119 flag=0;
120 }
121 }
122 ny=num;
123 memset(edges,0,sizeof(edges));
124 for(int i=0;i<n;i++)
125 for(int j=0;j<m;j++)
126 {
127 if(pic[i][j]=='o')
128 edges[sx[i][j]][sy[i][j]]=1;
129 }
130 match();
131 }
132 return 0;
133 }
Place the Robots 需要较强的建图能力的更多相关文章
- Codeforces 938D. Buy a Ticket (最短路+建图)
		<题目链接> 题目大意: 有n座城市,每一个城市都有一个听演唱会的价格,这n座城市由m条无向边连接,每天变都有其对应的边权.现在要求出每个城市的人,看一场演唱会的最小价值(总共花费的价值= ... 
- ZOJ 1654 Place the Robots建图思维(分块思想)+二分匹配
		题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=654 AC一百道水题,不如AC一道难题来的舒服. 题意:一个n*m地图 ... 
- [SDOI2010] 所驼门王的宝藏 [建图+tarjan缩点+DAG dp]
		题面传送门: 传送门 思路: 看完题建模,容易得出是求单向图最长路径的问题 那么把这张图缩强联通分量,再在DAG上面DP即可 然而 这道题的建图实际上才是真正的考点 如果对于每一个点都直接连边到它所有 ... 
- Codeforces Round #545 (Div. 2) E 强连通块 + dag上求最大路径 + 将状态看成点建图
		https://codeforces.com/contest/1138/problem/E 题意 有n个城市(1e5),有m条单向边(1e5),每一周有d天(50),对于每个城市假如在某一天为1表示这 ... 
- 【BZOJ-1570】BlueMary的旅行     分层建图 + 最大流
		1570: [JSOI2008]Blue Mary的旅行 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 388 Solved: 212[Submit ... 
- 【BZOJ-4289】Tax      最短路 + 技巧建图
		4289: PA2012 Tax Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 168 Solved: 69[Submit][Status][Dis ... 
- CF467D Fedor and Essay 建图DFS
		Codeforces Round #267 (Div. 2) CF#267D D - Fedor and Essay D. Fedor and Essay time limit per test ... 
- UVa 3487 & 蜜汁建图
		题意: 有两家公司都想向政府申请某些资源的使用权,并且他们都提供了一些申请列表,列表中含有申请费用和资源种类,同一家公司的申请列表之间不含有重复的资源.政府只可以完整地接受和拒绝谋一份申请列表,问政府 ... 
- POJ 2226 最小点覆盖(经典建图)
		Muddy Fields Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8881 Accepted: 3300 Desc ... 
随机推荐
- centos7下cups + samba共打印服务
			centos7下cups + samba共打印服务 2015年8月21日admin发表评论阅读评论 这个算是rhce课程的篇外篇,Samba除了提供文件共享外,也可以像windows下的共享一样提 ... 
- 目录和文件 按创建时间排序du -h --time --max-depth=1 . |sort -r -t $'\t' -k 2 Linux查看文件夹大小,并按文件夹创建时间排序
			目录和文件 按创建时间排序 # du -h --time --max-depth=1 . |sort -r -t $'\t' -k 230M 2020-04-01 14:54 .28K 2020-04 ... 
- mysql基础之数据库备份和恢复实操
			一.基于二进制文件的恢复*** 1.算好要恢复数据的时间段,重定向输入到bin.sql文件中 [root@ren7 mysql]# mysqlbinlog --start-datetime=" ... 
- STM32用FreeRTOS时任务优先级和中断优先级说明
			下面对 FreeRTOS 优先级相关的几个重要知识点进行下说明,这些知识点在以后的使用中务必要掌握牢固. FreeRTOS 中任务的最高优先级是通过 FreeRTOSConfig.h 文件中的 co ... 
- Prometheus存储原理及数据备份还原
			prometheus将采集到的样本以时间序列的方式保存在内存(TSDB 时序数据库)中,并定时保存到硬盘中.与zabbix不同,zabbix会保存所有的数据,而prometheus本地存储会保存15天 ... 
- 第一章 DevOps概述
			什么是软件开发 软件开发是根据用户要求建造出软件系统或者系统中的软件部分的过程. 软件开发是一项包括需求捕捉,需求分析,实现和测试的系统工程 软件开发有哪些困难? 软件开发的本质困难 复杂性 不可见性 ... 
- 关于Python闭包的一切
			任何把函数当做一等对象的语言,它的设计者都要面对一个问题:作为一等对象的函数在某个作用域中定义,但是可能会在其他作用域中调用,如何处理自由变量? 自由变量(free variable),未在局部作用域 ... 
- Nginx/LVS/HAProxy对比分析
			Nginx/LVS/HAProxy简单介绍: Nginx:专为性能优化而开发,性能是其最重要的考量,实现上非常注重效率 .它支持内核Poll模型,能经受高负载的考验,有报告表明能支持高达 50,000 ... 
- Python将PDF转为TXT
			PDFMiner----python的PDF解析器和分析器 1.官方文档:http://www.unixuser.org/~euske/python/pdfminer/index.html 2.特征 ... 
- idea开发web项目框架失效和无法启动问题
			不会配置idea的javaweb环境的小伙伴可以点击此链接 idea最新版,配置javaweb环境 很多小伙伴用idea开发web项目可能会出现所有代码都写对了但是无论如何都没法运行的情况,eclip ... 
