有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(二分图的最大独立集)

    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 (匈牙利算法 最大独立集)

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

  5. 网络流(最大独立点集):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 (ZOJ 1137 )最大独立点集

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

随机推荐

  1. UVa 272 Tex Quotes --- 水题

    题目大意:在TeX中,左引号是 ``,右引号是 ''.输入一篇包含双引号的文章,你的任务是把他转成TeX的格式 解题思路:水题,定义一个变量标记是左引号还是右引号即可 /* UVa 272 Tex Q ...

  2. php构造函数实例讲解

    PHP官网定义: 复制代码 代码如下: 构造函数是类中的一个特殊函数,当使用 new 操作符创建一个类的实例时,构造函数将会自动调用.当函数与类同名时,这个函数将成为构造函数.如果一个类没有构造函数, ...

  3. mysql5.6启动占用内存很大的解决方法

    vps的内存为512M,安装好nginx,php等启动起来,mysql死活启动不起来看了日志只看到对应pid被结束了,后跟踪看发现是内存不足被killed; 调整my.cnf 参数,重新配置(系统默认 ...

  4. 关于jquery easyui treegrid的问题

    我是用的django web开发架构: 想实现如下功能: 权限架构 点击checkbox时,能获取该checkbox的值: 代码如下: <tr> <th field="na ...

  5. JS页面间传值

    一:JavaScript静态页面值传递之URL篇 能过URL进行传值.把要传递的信息接在URL上. 例子: 参数传出页面Post.htm—>   <input type="tex ...

  6. c#强制执行内存回收

    [DllImport("psapi.dll")] private static extern int EmptyWorkingSet(int hProcess); GC.Colle ...

  7. 当用GridView导出Execl的时候,会发生只能在执行 Render() 的过程中调用 RegisterForEventValidation的错误

    当用GridView导出Execl的时候,会发生只能在执行 Render() 的过程中调用 RegisterForEventValidation的错误提示. 有两种方法可以解决以上问题: 1.修改we ...

  8. maxscript,#号和$号

    一,#号: 1,数组 #(123, "hi") 2,系统目录 fileName = getDir #scripts + "\\xxx.ms" 二,$号 节点路径 ...

  9. ubutntu apt 源

    中国开源软件中心更新服务器(北京光环新网 服务器),包含其他开源镜像: deb http://mirrors.oss.org.cn/ubuntu/ vivid main restricted univ ...

  10. 【转】3篇:Xilium CefGlue 关于 CLR Object 与 JS 交互类库封装报告:官方原生方法分析

    作者: 牛A与牛C之间 时间: 2013-11-17 分类: 技术文章 | 暂无评论 | 编辑文章 主页 » 技术文章 » 第3篇:Xilium CefGlue 关于 CLR Object 与 JS ...