BZOJ.3140.[HNOI2013]消毒(二分图匹配 匈牙利)
不难想到每次一定是切一片。
如果是平面,很容易想到直接做二分图匹配。对于3维的?
可以发现min(a,b,c)的最大值只有\(\sqrt[3]{n}≈17\),我们暴力枚举这一最小值代表的是否选,对于剩下的两维二分图匹配
能用匈牙利用什么网络流啊。。那么麻烦。
在匈牙利求解的过程中记得剪枝!
因为实际点数应该远不如ABC多,所以不要用memset,直接枚举。
woc卡着时过去 那些2000ms怎么过的??网上找不到快点的懒得找。
zz的我考场写的每次DFS完重建边+ISAP,成功都T掉(写的方式也很zz。。每次A*B*C枚举找点,3次讨论3个DFS)
感觉数据一点梯度没有全都5s过。。
//2120kb 9300ms
#include <cstdio>
#include <cctype>
#include <cstring>
#include <algorithm>
#define gc() getchar()
const int N=5005,M=20005;
int A,B,C,Time,bit[1<<18],Enum,H[N],nxt[M],to[M],match[N],use[N]/*空间换时间,匈牙利常用套路?*/;
struct Node
{
int x,y,z;
Node() {}
Node(int x,int y,int z):x(x),y(y),z(z) {}
}node[N];
inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-'0',c=gc());
return now;
}
inline void AddEdge(int u,int v){
to[++Enum]=v, nxt[Enum]=H[u], H[u]=Enum;
}
bool Can(int x)
{
for(int i=H[x]; i; i=nxt[i])
if(use[to[i]]!=Time)
{
use[to[i]]=Time;
if(!match[to[i]]||Can(match[to[i]]))
{
match[to[i]]=x; return 1;
}
}
return 0;
}
void Work()
{
A=read(),B=read(),C=read();
int cnt=0, f=1, lim=1<<A, Max=B;
if(B<A&&B<C) f=2,lim=1<<B,Max=A;
else if(C<A&&C<B) f=3,lim=1<<C,Max=A;
for(int v,i=1; i<=A; ++i)
for(int j=1; j<=B; ++j)
for(int k=1; k<=C; ++k)
if(v=read()){
if(f==1) node[++cnt]=Node(i,j,k);//直接交换顺序即可
else if(f==2) node[++cnt]=Node(j,i,k);
else node[++cnt]=Node(k,i,j);
}
int Ans=10000;
for(int res,s=0; s<lim; ++s)
{
Enum=0, res=bit[s];//Time并不需要清空
// memset(H,0,sizeof H), memset(match,0,sizeof match);
for(int i=1; i<=Max; ++i) H[i]=match[i]=0;//here!
for(int i=1; i<=cnt; ++i)
if(!(s&(1<<node[i].x-1))) AddEdge(node[i].y,node[i].z);
++Time;
for(int i=1; i<=Max; ++i,++Time)
if(Can(i)){
if(++res>=Ans) break;//剪枝!
}
Ans=std::min(res,Ans);
}
printf("%d\n",Ans);
}
int main()
{
for(int i=1; i<(1<<17); ++i) bit[i]=bit[i>>1]+(i&1);
int T=read();
while(T--) Work();
return 0;
}
BZOJ.3140.[HNOI2013]消毒(二分图匹配 匈牙利)的更多相关文章
- bzoj 3140: [Hnoi2013]消毒
3140: [Hnoi2013]消毒 Description 最近在生物实验室工作的小T遇到了大麻烦. 由于实验室最近升级的缘故,他的分格实验皿是一个长方体,其尺寸为a*b*c,a.b.c 均为正整数 ...
- [bzoj]1059矩阵游戏<二分图匹配*匈牙利算法>
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1059 初见此题,我觉得这是水题,我认为只要每一行和每一列至少存在一个黑格就可以出现对角线, ...
- [HNOI2013] 消毒 - 二分图匹配
容易发现 \(a,b,c\) 中至少有一个 \(\leq 17\) 不妨将其调剂为 \(a\),那么我们可以暴力枚举哪些 \(x\) 片片要被直接削掉,剩下的拍扁成二维情况 二维时,如果有一个格子是 ...
- 【刷题】BZOJ 3140 [Hnoi2013]消毒
Description 最近在生物实验室工作的小T遇到了大麻烦. 由于实验室最近升级的缘故,他的分格实验皿是一个长方体,其尺寸为abc,a.b.c 均为正整数.为了实验的方便,它被划分为abc个单位立 ...
- [BZOJ3140][HNOI2013]消毒(二分图最小点覆盖)
3140: [Hnoi2013]消毒 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1621 Solved: 676[Submit][Status] ...
- HDU 5943 Kingdom of Obsession 【二分图匹配 匈牙利算法】 (2016年中国大学生程序设计竞赛(杭州))
Kingdom of Obsession Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Oth ...
- USACO 4.2 The Perfect Stall(二分图匹配匈牙利算法)
The Perfect StallHal Burch Farmer John completed his new barn just last week, complete with all the ...
- [ZJOI2009]假期的宿舍 二分图匹配匈牙利
[ZJOI2009]假期的宿舍 二分图匹配匈牙利 一个人对应一张床,每个人对床可能不止一种选择,可以猜出是二分图匹配. 床只能由本校的学生提供,而需要床的有住校并且本校和外校两种人.最后统计二分图匹配 ...
- 3140:[HNOI2013]消毒 - BZOJ
题目描述 Description 最近在生物实验室工作的小 T 遇到了大麻烦. 由于实验室最近升级的缘故,他的分格实验皿是一个长方体,其尺寸为 a*b*c,a.b.c均为正整数.为了实验的方便,它被划 ...
随机推荐
- f-GAN
学习总结于国立台湾大学 :李宏毅老师 f-GAN: Training Generative Neural Samplers using Variational Divergence Minimizat ...
- pytorch官网上两个例程
caffe用起来太笨重了,最近转到pytorch,用起来实在不要太方便,上手也非常快,这里贴一下pytorch官网上的两个小例程,掌握一下它的用法: 例程一:利用nn 这个module构建网络,实现 ...
- 嵌入式Linux驱动笔记(十八)------浅析V4L2框架之ioctl【转】
转自:https://blog.csdn.net/Guet_Kite/article/details/78574781 权声明:本文为 风筝 博主原创文章,未经博主允许不得转载!!!!!!谢谢合作 h ...
- 福利爬虫妹子图之获取种子url
import os import uuid from lxml import html import aiofiles import logging from ruia import Spider, ...
- nodejs 数据库操作,消息的发送和接收,模拟同步
var deasync = require('deasync'); //导入模板 var mysql=require('mysql'); var Stomp = require('stompjs'); ...
- openstack常见问题解决方法总结
一.创建实例失败: 首先用下面命令查看服务是否正常 1. nova-manage service list 如果不正常,则使用下面命令重启,如果还不行,则查看日志, 1. service nova-a ...
- mysql字符串 转 int-double CAST与CONVERT 函数的用法
MySQL 的CAST()和CONVERT()函数可用来获取一个类型的值,并产生另一个类型的值.两者具体的语法如下: CAST(value as type); CONVERT(value, type) ...
- vmware下centos克隆功能对网络的设置
centos完成克隆功能后需要对网络进行设置 # cd /etc/udev/rules.d/ vim 70-persistent-net.rules 删除eth0的配置,将eth1该为eth0 编辑网 ...
- wordpress安装主题时提示无法创建目录
直接上解决办法: 找到wp-content文件夹(我的是在/home/wwwroot/default/wp-cotent) 首先给wp-content这个文件夹一个权限 chmod -R 775 wp ...
- 输入一个数,求1到他 的和(for循环)