p2055&bzoj1433 假期的宿舍
题目
Input
Output
对于每组数据,如果存在一个方案则输出“^_^”(不含引号)否则输出“T_T”(不含引号)。
Sample Input
3
1 1 0
0 1 0
0 1 1
1 0 0
1 0 0
Sample Output
分析
这是一个二分图匹配问题,我们将所有不回家的在校学生和来看他们的人作为左面,将他们与所有在校学生匹配,如果全能匹配则可以,否则不行,注意如果需匹配的人数大于总床数则一定不行
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
int in[];
int used[],g[][],wh[],n,m,a[],b[],t;
inline bool work(int x){
for(int i=;i<=m;i++)
if(used[i]!=t&&g[a[x]][b[i]]){
used[i]=t;
if(!wh[i]||work(wh[i])){
wh[i]=x;
return ;
}
}
return ;
}
inline bool go(){
if(n>m)return ;
for(int i=;i<=n;i++){
t=i;
if(!work(i))return ;
}
return ;
}
int main()
{ int i,j,k,t;
scanf("%d",&t);
while(t--){
memset(used,,sizeof(used));
memset(g,,sizeof(g));
memset(wh,,sizeof(wh));
memset(in,,sizeof(in));
n=,m=;
scanf("%d",&k);
for(i=;i<=k;i++){
scanf("%d",&j);
if(j)b[++m]=i,in[i]=;
else a[++n]=i;
}
for(i=;i<=k;i++){
scanf("%d",&j);
if(!in[i])continue;
if(!j)a[++n]=i;
}
for(i=;i<=k;i++)
for(j=;j<=k;j++){
scanf("%d",&g[i][j]);
if(in[i]&&i==j)g[i][j]=;
}
if(go())printf("^_^\n");
else printf("T_T\n");
}
return ;
}
p2055&bzoj1433 假期的宿舍的更多相关文章
- 洛谷P2055 [ZJOI2009]假期的宿舍
		
P2055 [ZJOI2009]假期的宿舍 题目描述 学校放假了 · · · · · · 有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如 A 和 B 都是学校的学生,A ...
 - 洛谷——P2055 [ZJOI2009]假期的宿舍
		
P2055 [ZJOI2009]假期的宿舍 学校放假了 · · · · · · 有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如 A 和 B 都是学校的学生,A 要回家,而 ...
 - P2055 [ZJOI2009]假期的宿舍 题解(二分图)
		
题目链接 P2055 [ZJOI2009]假期的宿舍 解题思路 因为懒,提供一种不连边,直接根据题目给出的邻接矩阵进行匈牙利算法的思路. \(a[i][j]\)表示\(i\)能不能睡\(j\)的床,需 ...
 - 洛谷 P2055 【假期的宿舍】
		
题库 :洛谷 题号 :2055 题目 :假期的宿舍 link :https://www.luogu.org/problem/P2055 首先明确一下:校内的每个学生都有一张床(只是校内的有) 思路 : ...
 - BZOJ-1433   假期的宿舍      最大流+基础建图
		
网络流练习ing.. 1433: [ZJOI2009]假期的宿舍 Time Limit: 10 Sec Memory Limit: 162 MB Submit: 1748 Solved: 765 [S ...
 - 洛谷 P2055 [ZJOI2009]假期的宿舍
		
洛谷 P2055 题目描述 学校放假了 · · · · · · 有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如 A 和 B 都是学校的学生,A 要回家,而 C 来看B,C ...
 - 洛谷P2055 [ZJOI2009]假期的宿舍 题解
		
题目链接: https://www.luogu.org/problemnew/show/P2055 分析: 这道题比较简单,二分图的练习题(当然最大流同理). 易得我们可以将人放在一侧,床放在一侧. ...
 - 洛谷P2055 [ZJOI2009]假期的宿舍 [二分图最大匹配]
		
题目描述 学校放假了 · · · · · · 有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如 A 和 B 都是学校的学生,A 要回家,而 C 来看B,C 与 A 不认识. ...
 - P2055 [ZJOI2009]假期的宿舍
		
思路 看到复杂的匹配条件,发现要让一个人和一个床匹配,所以就每个有床的人(指本校学生)和t连一条边,每个需要床的人(指外校的人和不回家的人)和s连一条边,i和j互相认识就把i和j的床连在一起,自己和自 ...
 
随机推荐
- css 行内元素 块元素 替换元素 非替换元素 以及这些元素的width height margin padding 特性
			
一.各种元素的width height margin padding 特性(具体css元素的分来参看二) 1.块级元素 width. height. margin的四个方向. padding的四个方向 ...
 - 前端开发笔记--flex布局
			
flex布局: 个人觉得flex布局比起传统布局要优先得多(主要是容易使用),缺点是IE10及以上版本才能使用,甚至某些属性只有在IE11才能使用(而且我发现凡是不兼容主要IE的坑来的多,不是说其他浏 ...
 - DIV+CSS专题:第一天 XHTML CSS基础知识
			
欢迎大家学习<十天学会web标准>,也就是我们常说的DIV+CSS.不过这里的DIV+CSS是一种错误的叫法,建议大家还是称之为web标准. 学习本系列教程需有一定html和css基础 ...
 - 模拟RPG格斗
			
三个英雄角色参与PK 每个英雄具有以下几个属性:生命值(为0时英雄倒下).攻击力(每次攻击时扣除对方的生命值点数).攻击间隔(每次攻击过后都要等待间隔时间才能进行下次攻击,首次攻击之前也要先等待间隔时 ...
 - Git教程及问题解析
			
本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! Git教程 最近用git比较多,做出教程一份,供大家参考. 1. 安装Git,并配置环 ...
 - python-socket2
			
UDP,服务端 #! /usr/bin/env python #coding=utf-8 import socket #创建socket,指定ipv4,udp类型 s = socket.socket( ...
 - 13 Python 函数进阶
			
代码在运行伊始,创建的存储“变量名与值的关系”的空间叫做全局命名空间,在函数的运行中开辟的临时的空间叫做局部命名空间 命名空间和作用域 命名空间的本质:存放名字与值的绑定关系 >>> ...
 - javascript笔记(二)
			
concat() 连接多个字符串,返回合并后的字符串. 1 var s1="a"; 2 var s2="b"; 3 var s3="c"; ...
 - codeforces 598E E. Chocolate Bar(区间dp)
			
题目链接: E. Chocolate Bar time limit per test 2 seconds memory limit per test 256 megabytes input stand ...
 - linux命令学习笔记(53):route命令
			
Linux系统的route命令用于显示和操作IP路由表(show / manipulate the IP routing table).要实现两 个不同的子网之间的通信,需要一台连接两个网络的路由器, ...