POJ 1466 Girls and Boys 黑白染色 + 二分匹配 (最大独立集) 好题

时间:2022-09-30 17:42:42

有n个人, 其中有男生和女生,接着有n行,分别给出了每一个人暗恋的对象(不止暗恋一个)

现在要从这n个人中找出一个最大集合,满足这个集合中的任意2个人,都没有暗恋这种关系。

输出集合的元素个数。

刚开始想,把人看成顶点,若有暗恋的关系,就连一条边,构成一个图

独立集的概念:一个图中两两互不相连的顶点集合

所以这道题,就是要求最大独立集

有:最大独立集+最小顶点覆盖=|V|(顶点的总个数)

那就求最小顶点覆盖了

根据题意:

暗恋的对象性别不同,所以a暗恋b,b暗恋c,c暗恋a这种关系不可能存在

也就是说,这个图的顶点可以根据性别分成2个集合,男生和女生

即这是一个二分图

我们知道,在二分图中,最小顶点覆盖=最大匹配

则:最大独立集=|V|-最大匹配

所以思路就清晰了:

1.黑白染色:确定男生和女生

2.建图:s连边到所有男生,所有女生连边到t,若男生i和女生j有关系,则连一条边,边的容量都是1

3.二分匹配转化为最大流求解

4.|V|-最大匹配

 #include<cstdio>
#include<cstring>
#include<vector>
#include<queue> using namespace std; const int maxn=;
const int inf=0x3f3f3f3f;
int s;
int t; inline int min(int x,int y)
{
return x<y?x:y;
} struct Edge
{
int to,cap,rev;
};
vector<Edge>edge[maxn];
int level[maxn];
int iter[maxn];
int dye[maxn]; void addedge(int from,int to,int cap)
{
edge[from].push_back((Edge){to,cap,edge[to].size()});
edge[to].push_back((Edge){from,,edge[from].size()-});
} struct Edge1
{
int to,next;
};
Edge1 edge1[maxn*];
int head[maxn],tot; void init()
{
memset(head,-,sizeof head);
tot=;
memset(dye,-,sizeof dye);
} void addedge1(int from,int to)
{
edge1[tot].to=to;
edge1[tot].next=head[from];
head[from]=tot++;
} void get_dye(int u,int pre)
{
if(pre==-)
dye[u]=;
else
dye[u]=!dye[pre];
for(int i=head[u];~i;i=edge1[i].next)
{
int v=edge1[i].to;
if(v==pre)
continue;
if(dye[v]!=-)
continue;
get_dye(v,u);
}
} void build_graph(int n)
{
s=n;
t=n+;
for(int i=;i<=t;i++)
edge[i].clear();
for(int i=;i<n;i++)
{
if(dye[i]==)
{
addedge(s,i,);
for(int j=head[i];~j;j=edge1[j].next)
{
int v=edge1[j].to;
addedge(i,v,);
}
}
else
addedge(i,t,);
}
} void bfs()
{
memset(level,-,sizeof level);
queue<int>que;
while(!que.empty())
que.pop();
que.push(s);
level[s]=;
while(!que.empty())
{
int u=que.front();
que.pop();
for(int i=;i<edge[u].size();i++)
{
Edge &e=edge[u][i];
if(e.cap>&&level[e.to]<)
{
level[e.to]=level[u]+;
que.push(e.to);
}
}
}
} int dfs(int u,int f)
{
if(u==t)
return f;
for(int &i=iter[u];i<edge[u].size();i++)
{
Edge &e=edge[u][i];
if(e.cap>&&level[e.to]>level[u])
{
int d=dfs(e.to,min(e.cap,f));
if(d)
{
e.cap-=d;
edge[e.to][e.rev].cap+=d;
return d;
}
}
}
return ;
} int solve()
{
int flow=;
while()
{
bfs();
if(level[t]<)
return flow;
memset(iter,,sizeof iter);
int f;
while(f=dfs(s,inf))
{
flow+=f;
}
}
} int main()
{
int n;
while(~scanf("%d",&n))
{
init();
for(int i=;i<n;i++)
{
int j;
char ch;
scanf("%d%c",&j,&ch);
char str[];
scanf("%s",str);
int len=strlen(str);
int num=;
for(int k=;k<len-;k++)
{
num=num*+(str[k]-'');
}
for(int k=;k<num;k++)
{
int tmp;
scanf("%d",&tmp);
addedge1(j,tmp);
addedge1(tmp,j);
}
} for(int i=;i<n;i++)
{
if(dye[i]==-)
get_dye(i,-);
}
build_graph(n);
printf("%d\n",n-solve());
}
return ;
}

POJ 1466 Girls and Boys 黑白染色 + 二分匹配 (最大独立集) 好题的更多相关文章

  1. poj 1466 Girls and Boys&lpar;二分图的最大独立集)

    http://poj.org/problem?id=1466 Girls and Boys Time Limit: 5000MS   Memory Limit: 10000K Total Submis ...

  2. POJ 1466 Girls and Boys

    Girls and Boys Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://poj.org/problem?id=1466 Descripti ...

  3. poj 1466 Girls and Boys 二分图的最大匹配

    Girls and Boys Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://poj.org/problem?id=1466 Descripti ...

  4. POJ 1466 Girls and Boys &lpar;匈牙利算法 最大独立集&rpar;

    Girls and Boys Time Limit: 5000MS   Memory Limit: 10000K Total Submissions: 10912   Accepted: 4887 D ...

  5. 网络流&lpar;最大独立点集&rpar;:POJ 1466 Girls and Boys

    Girls and Boys Time Limit: 5000ms Memory Limit: 10000KB This problem will be judged on PKU. Original ...

  6. poj 1466 Girls and Boys (最大独立集)

    链接:poj 1466 题意:有n个学生,每一个学生都和一些人有关系,如今要你找出最大的人数.使得这些人之间没关系 思路:求最大独立集,最大独立集=点数-最大匹配数 分析:建图时应该是一边是男生的点, ...

  7. poj 1466 Girls and Boys(二分匹配之最大独立集)

    Description In the second year of the university somebody started a study on the romantic relations ...

  8. POJ 1466 Girls and Boys(二分图匹配)

    [题目链接] http://poj.org/problem?id=1466 [题目大意] 给出一些人和他们所喜欢的人,两个人相互喜欢就能配成一对, 问最后没有配对的人的最少数量 [题解] 求最少数量, ...

  9. POJ 1466 Girls and Boys &lpar;ZOJ 1137 &rpar;最大独立点集

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=137 http://poj.org/problem?id=1466 题目大意: ...

随机推荐

  1. Git 版本管理的简单理解

    来源:百度知道 现在使用Git版本管理代码的项目非常多.但是Git本身是一条复杂的系统.我从几个简单的点来说明Git的基本功能.希望能帮助初学者快速入门. 工具/原料   Git code dot j ...

  2. ajax同步的实现

    if (window.XMLHttpRequest) {// code for IE7, Firefox, Opera, etc. xmlhttp=new XMLHttpRequest(); }els ...

  3. BestCoder Round &num;85

    sum Accepts: 640 Submissions: 1744 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/13107 ...

  4. 三、 添加视图View(ASP&period;NET MVC5 系列)

    在这一章节我们可以修改HelloWorldController类,通过使用视图模板来封装处理产生给客户端的HTML响应. 我们将使用Razor View engine来创建视图文件.基于Razor的视 ...

  5. 03 EditText文本编辑框

    二  EditText   文本编辑框  父类: TextView     >概念:文本编辑框  可以进行文本编辑         android:textColor="#00f&qu ...

  6. verdi&bsol;debussy的使用技巧

    verdi\debussy的使用技巧 转载from 大西瓜FPGA 大西瓜FPGA-->https://daxiguafpga.taobao.com fsdb display Debussy本身 ...

  7. dic and set

    一.dic 1.格式:key:value 2.key值必须不可变(可hash) 3.key不可重复(唯一性) 4.优点:查找.插入速度快 5.缺点:空间消耗大 6.实质是以空间换速度 7.常用参数 1 ...

  8. WEB 性能优化导图

    看了一下网上对于web性能优化的一些帖子,不是很直观,花了点时间画了一个思维导图. refers: https://segmentfault.com/a/1190000011936772 https: ...

  9. &lbrack;Jsoi2013&rsqb;快乐的jyy

    题目 这个需要我们瞎\(yy\)一下就能做了 我们先对于第一个串建立\(PAM\) 我们把第二个串丢上去匹配,这里匹配出来的是以每一个位置为结尾且在另一个串里存在的最长回文后缀的长度 对于每一个位置开 ...

  10. CAN总线学习系列之三——CAN控制器的选择

    CAN总线学习系列之三——CAN控制器的选择 在进行CAN总线开发前,首先要选择好CAN总线控制器.下面就比较一些控制器的特点. 一些主要的CAN总线器件产品 制造商 产品型号 器件功能及特点 Int ...