1433: [ZJOI2009]假期的宿舍

Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 4157  Solved: 1805
[Submit][Status][Discuss]

Description

学校放假了······有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题。比如A

和B都是学校的学生,A要回家,而C来看B,C与A不认识。我们假设每个人只能睡和自己直接认识的人的床。那么一

个解决方案就是B睡A的床而C睡B的床。而实际情况可能非常复杂,有的人可能认识好多在校学生,在校学生之间也

不一定都互相认识。我们已知一共有n个人,并且知道其中每个人是不是本校学生,也知道每个本校学生是否回家

。问是否存在一个方案使得所有不回家的本校学生和来看他们的其他人都有地方住。

Input

第一行一个数T表示数据组数。接下来T组数据,

每组数据第一行一个数n表示涉及到的总人数。

接下来一行n个数,第i个数表示第i个人是否是在校学生(0表示不是,1表示是)。

再接下来一行n个数,第i个数表示第i个人是否回家

(0表示不回家,1表示回家,注意如果第i个人不是在校学生,那么这个位置上的数是一个随机的数,

你应该在读入以后忽略它)。

接下来n行每行n个数,

第i行第j个数表示i和j是否认识

(1表示认识,0表示不认识,第i行i个的值为0,但是显然自己还是可以睡自己的床),

认识的关系是相互的。

1 ≤ n ≤ 50,1 ≤ T ≤ 20

Output

对于每组数据,如果存在一个方案则输出“^_^”(不含引号)否则输出“T_T”(不含引号)。

(注意输出的都是半角字符,即三个符号的ASCII码分别为94,84,95)

Sample Input

1
3
1 1 0
0 1 0
0 1 1
1 0 0
1 0 0

Sample Output

ˆ ˆ

几乎是裸的二分图匹配

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 using namespace std;
 5
 6 int T,n,sn,gn;
 7 int a[100],b[100],match[100];
 8 bool mp[100][100],vis[100];
 9 bool flag;
10
11 bool find(int x)
12 {
13     for(int i=1;i<=n;i++)
14         if(mp[x][i]&&!vis[i])
15         {
16             vis[i]=1;
17             if(match[i]==0||find(match[i]))
18             {
19                 match[i]=x;
20                 return true;
21             }
22         }
23     return false;
24 }
25
26 int main()
27 {
28     scanf("%d",&T);
29     while(T--)
30     {
31         flag=1;
32         memset(match,0,sizeof(match));
33         scanf("%d",&n);
34         for(int i=1;i<=n;i++) scanf("%d",&a[i]);
35         for(int i=1;i<=n;i++)
36         {
37             scanf("%d",&b[i]);
38             if(!a[i]) b[i]=0;
39         }
40         for(int i=1;i<=n;i++)
41             for(int j=1;j<=n;j++)
42             {
43                 int x;
44                 scanf("%d",&x);
45                 if(i==j) x=1;
46                 if(a[j]&&x) mp[i][j]=1;
47                 else mp[i][j]=0;
48             }
49         for(int i=1;i<=n;i++)
50         {
51             memset(vis,0,sizeof(vis));
52             if(!b[i]&&!find(i))
53             {
54                 flag=0;
55                 break;
56             }
57         }
58         if(flag) printf("^_^\n");
59         else printf("T_T\n");
60     }
61     return 0;
62 }

原文地址:https://www.cnblogs.com/InWILL/p/9735731.html

时间: 2024-10-18 23:18:09

1433: [ZJOI2009]假期的宿舍的相关文章

bzoj 1433: [ZJOI2009]假期的宿舍 -- 最大流

1433: [ZJOI2009]假期的宿舍 Time Limit: 10 Sec  Memory Limit: 162 MB Description Input Output Sample Input 1 3 1 1 0 0 1 0 0 1 1 1 0 0 1 0 0 Sample Output ˆ ˆ HINT 对于30% 的数据满足1 ≤ n ≤ 12.对于100% 的数据满足1 ≤ n ≤ 50,1 ≤ T ≤ 20. 我们从源点向所有住宿的人连边,从所有的床位连向汇点,然后再从人连向他所

bzoj 1433: [ZJOI2009]假期的宿舍

1 #include<cstdio> 2 #include<iostream> 3 #include<cstring> 4 #define M 100009 5 #define inf 2139062143 6 using namespace std; 7 int n,m,a[102],tot,cnt=1,T,ans,head[M],d[M],q[2*M],next[10*M],u[10*M],v[10*M],T1; 8 int xx[4]={0,0,1,-1},yy[

bzoj 1433: [ZJOI2009]假期的宿舍【匈牙利算法】

i能睡j床的连边(i,j),跑最大匹配或者最大流,然后看看人数能不能对上总数即可 #include<iostream> #include<cstdio> #include<cstring> using namespace std; const int N=1005; int T,n,a[N],b[N],h[N],cnt,con,ans,lk[N],v[N],ti; struct qwe { int ne,to; }e[N*N]; void add(int u,int v

[ZJOI2009]假期的宿舍

1433: [ZJOI2009]假期的宿舍 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2870  Solved: 1213[Submit][Status][Discuss] Description Input Output Sample Input 1 3 1 1 0 0 1 0 0 1 1 1 0 0 1 0 0 Sample Output ˆ ˆ HINT 对于30% 的数据满足1 ≤ n ≤ 12.对于100% 的数据满足1 ≤ n ≤

bzoj1433:[ZJOI2009]假期的宿舍

明显的二分图最大匹配. #include<cstdio> #include<cstring> #include<cctype> #include<algorithm> #include<bitset> using namespace std; #define rep(i,s,t) for(int i=s;i<=t;i++) #define dwn(i,s,t) for(int i=s;i>=t;i--) #define clr(x,c

bzoj1433: [ZJOI2009]假期的宿舍

1433: [ZJOI2009]假期的宿舍 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2286  Solved: 969[Submit][Status][Discuss] Description Input Output Sample Input 131 1 00 1 00 1 11 0 01 0 0 Sample Output ˆ ˆ HINT 对于30% 的数据满足1 ≤ n ≤ 12.对于100% 的数据满足1 ≤ n ≤ 50,1 ≤

bzoj1433[ZJOI2009]假期的宿舍(匈牙利)

1433: [ZJOI2009]假期的宿舍 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2544  Solved: 1074 [Submit][Status][Discuss] Description Input Output Sample Input 1 3 1 1 0 0 1 0 0 1 1 1 0 0 1 0 0 Sample Output ˆ ˆ HINT 对于30% 的数据满足1 ≤ n ≤ 12.对于100% 的数据满足1 ≤ n

bzoj1433 [ZJOI2009]假期的宿舍(最大流)

1433: [ZJOI2009]假期的宿舍 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1717  Solved: 754[Submit][Status][Discuss] Description Input Output Sample Input 1 3 1 1 0 0 1 0 0 1 1 1 0 0 1 0 0 Sample Output ˆ ˆ HINT 对于30% 的数据满足1 ≤ n ≤ 12. 对于100% 的数据满足1 ≤ n ≤

luogu P2055 [ZJOI2009]假期的宿舍

二次联通门 : luogu P2055 [ZJOI2009]假期的宿舍 /* luogu P2055 [ZJOI2009]假期的宿舍 建图时分为两个集合 床一个集合 人一个集合 S到床连边 人与自己认识的人连边 人与T点连边 然后跑最大流判断即可 */ #include <algorithm> #include <iostream> #include <cstring> #include <cstdio> #include <queue> #de