【bzoj】1433】[ZJOI2009]假期的宿舍

按要求连边,跑匈牙利

#include<algorithm>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;

#define N 110

int T,n;

int sc[N],go[N];
int a[N][N];
int ly[N],vis[N];

struct edge
{
    int to,next;
}e[20010];
int head[N];
int cnt;

int getint()
{
    int w=0,q=0;
    char c=getchar();
    while ((c<‘0‘ || c>‘9‘) && c!=‘-‘)
        c=getchar();
    if (c==‘-‘)
        q=1,c=getchar();
    while (c>=‘0‘ && c<=‘9‘)
        w=w*10+c-‘0‘,c=getchar();
    return q?-w:w;
}  

void link(int x,int y)
{
    e[++cnt]=(edge){y,head[x]};
    head[x]=cnt;
}

bool find(int x)
{
    for (int i=head[x];i;i=e[i].next)
    {
        int t=e[i].to;
        if (!vis[t])
        {
            vis[t]=1;
            if (!ly[t] || find(ly[t]))
            {
                ly[t]=x;
                return true;
            }
        }
    }
    return false;
}

int main()
{
    T=getint();
    while (T--)
    {
        n=getint();
        for (int i=1;i<=n*2;i++)
            head[i]=0,ly[i]=0;
        cnt=0;
        for (int i=1;i<=n;i++)
            sc[i]=getint();
        for (int i=1;i<=n;i++)
        {
            go[i]=getint();
            if (sc[i] && !go[i])
                link(i,n+i);
        }
        for (int i=1;i<=n;i++)
        {
            for (int j=1;j<=n;j++)
                a[i][j]=getint();
            if (!sc[i] || (sc[i] && !go[i]))
            {
                for (int j=1;j<=n;j++)
                    if (a[i][j] && sc[j])
                        link(i,j+n);
            }
        }
        int f=1;
        for (int i=1;i<=n;i++)
            if (!sc[i] || (sc[i] && !go[i]))
            {
                for (int j=1;j<=n*2;j++)
                    vis[j]=0;
                if (!find(i))
                {
                    f=0;
                    break;
                }
            }
        if (f)
            puts("^_^");
        else
            puts("T_T");
    }
    return 0;
}

  

时间: 2024-10-12 12:01:24

【bzoj】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

1433: [ZJOI2009]假期的宿舍

Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4157  Solved: 1805[Submit][Status][Discuss] Description 学校放假了······有些同学回家了,而有些同学则有以前的好朋友来探访,那么住宿就是一个问题.比如A 和B都是学校的学生,A要回家,而C来看B,C与A不认识.我们假设每个人只能睡和自己直接认识的人的床.那么一 个解决方案就是B睡A的床而C睡B的床.而实际情况可能非常复杂,有的人可能认识好多在

[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