bzoj 2140: 稳定婚姻 (二分图)
//==========================
蒟蒻Macaulish:http://www.cnblogs.com/Macaulish/ 转载要声明!
//==========================
判断二分图中某条路是否是唯一的。
网络流做法要加个tarjan
二分图就是再增广看能不能增广
网络流(快但是长)
type
arr=record
toward,next,cap,from:longint;
end;
const
maxn=;
maxm=;
var
edge:array[..maxm]of arr;
first,cur,d,p,gap,num,e,belong,dfn,low:array[..maxn]of longint;
chose:array[..maxn]of boolean;
trie:array[..maxn,'A'..'z'] of longint;
n,esum,s,t,tot,total,peo,time,scc,top:longint; procedure add(j,k,l:longint);
begin
inc(esum);
edge[esum].toward:=k;
edge[esum].next:=first[j];
first[j]:=esum;
edge[esum].from:=j;
edge[esum].cap:=l;
end; procedure addedge(j,k,l:longint);
begin
add(j,k,l);
add(k,j,);
end; function find(ss:string):longint;
var
i,u:longint;
begin
u:=;
for i:= to length(ss) do u:=trie[u][ss[i]];
exit(num[u]);
end; function min(x,y:longint):longint;
begin
if x<y then exit(x);
exit(y);
end; procedure into;
var
i,j,k,m,u,boy,girl:longint;
ss:string;
begin
esum:=-;
tot:=;
total:=;
peo:=;
fillchar(first,sizeof(first),);
readln(n);
s:=n<<+;
t:=n<<+;
tot:=n<<+;
for i:= to n do begin readln(ss);
ss:=ss+' ';
u:=;
j:=;
while (ss[j]<>' ') do begin
if trie[u][ss[j]]= then begin
inc(total);
trie[u][ss[j]]:=total;
end;
u:=trie[u][ss[j]];
inc(j);
end;
inc(peo);
num[u]:=peo;
girl:=peo; inc(j);
u:=;
while (ss[j]<>' ') do begin
if trie[u][ss[j]]= then begin
inc(total);
trie[u][ss[j]]:=total;
end;
u:=trie[u][ss[j]];
inc(j);
end;
inc(peo);
num[u]:=peo;
boy:=peo; e[i]:=esum+;
addedge(girl,boy,);
addedge(s,girl,);
addedge(boy,t,); end;
readln(m);
while m> do begin
dec(m);
readln(ss);
i:=pos(' ',ss);
j:=find(copy(ss,,i-));
k:=find(copy(ss,i+,length(ss)-i));
addedge(j,k,);
end;
end; function sap(x,flow:longint):longint;
var
now,more,i,too:longint;
begin
if x=t then exit(flow);
now:=;
i:=cur[x];
while i>= do begin
too:=edge[i].toward;
if (d[x]=d[too]+) and (edge[i].cap>) then begin
more:=sap(too,min(flow-now,edge[i].cap));
dec(edge[i].cap,more);
inc(edge[i xor ].cap,more);
inc(now,more);
cur[x]:=i;
if flow=now then exit(flow);
end;
i:=edge[i].next;
end;
dec(gap[d[x]]);
if gap[d[x]]= then d[s]:=tot;
inc(d[x]);
inc(gap[d[x]]);
cur[x]:=first[x];
exit(now);
end; procedure maxflow;
var
i:longint;
begin
fillchar(gap,sizeof(gap),);
fillchar(d,sizeof(d),);
gap[]:=tot;
for i:= to tot do cur[i]:=first[i];
while d[s]<tot do sap(s,maxlongint);
end; procedure tarjan(x:longint);
var
i,j,too:longint;
begin
inc(time);
dfn[x]:=time;
low[x]:=time;
inc(top);
p[top]:=x;
chose[x]:=true;
i:=first[x];
while i>= do begin
if edge[i].cap> then begin
too:=edge[i].toward;
if dfn[too]= then begin
tarjan(too);
low[x]:=min(low[x],low[too]);
end
else
if chose[too] then
low[x]:=min(low[x],low[too]);
end;
i:=edge[i].next;
end;
if low[x]=dfn[x] then begin
inc(scc);
repeat
j:=p[top];
dec(top);
chose[j]:=false;
belong[j]:=scc;
until j=x;
end;
end; procedure work;
var
head,tail,i,j,k,l,x,too:longint;
flag:boolean;
begin
time:=;
fillchar(chose,sizeof(chose),false);
fillchar(dfn,sizeof(dfn),);
top:=;
for i:= to tot do
if dfn[i]= then tarjan(i);
for i:= to n do begin
j:=e[i];
k:=edge[j].from;
l:=edge[j].toward;
if (belong[k]=belong[l]) or (edge[j].cap>) then writeln('Unsafe')
else writeln('Safe');
end;
end; begin
into;
maxflow;
work;
end.
匈牙利版
type
arr=record
toward,next,from:longint;
flag:boolean;
end;
const
maxn=;
maxm=;
var
edge:array[..maxm]of arr;
first,cur,d,p,gap,num,e,match,matche:array[..maxn]of longint;
chose:array[..maxn]of boolean;
trie:array[..maxn,'A'..'z'] of longint;
n,esum,s,t,tot,total,peo,time,scc,top:longint; procedure addedge(j,k:longint);
begin
inc(esum);
edge[esum].from:=j;
edge[esum].toward:=k;
edge[esum].next:=first[j];
edge[esum].flag:=true;
first[j]:=esum;
end; function find(ss:string):longint;
var
i,u:longint;
begin
u:=;
for i:= to length(ss) do u:=trie[u][ss[i]];
exit(num[u]);
end; procedure into;
var
i,j,k,m,u,boy,girl:longint;
ss:string;
begin
esum:=;
tot:=;
total:=;
peo:=;
fillchar(first,sizeof(first),);
readln(n);
for i:= to n do begin readln(ss);
ss:=ss+' ';
u:=;
j:=;
while (ss[j]<>' ') do begin
if trie[u][ss[j]]= then begin
inc(total);
trie[u][ss[j]]:=total;
end;
u:=trie[u][ss[j]];
inc(j);
end;
inc(peo);
num[u]:=peo;
girl:=peo; inc(j);
u:=;
while (ss[j]<>' ') do begin
if trie[u][ss[j]]= then begin
inc(total);
trie[u][ss[j]]:=total;
end;
u:=trie[u][ss[j]];
inc(j);
end;
inc(peo);
num[u]:=peo;
boy:=peo; e[i]:=esum+;
addedge(girl,boy); end;
readln(m);
while m> do begin
dec(m);
readln(ss);
i:=pos(' ',ss);
j:=find(copy(ss,,i-));
k:=find(copy(ss,i+,length(ss)-i));
addedge(j,k);
end;
end; function dfs(x:longint):boolean;
var
i,too:longint;
begin
i:=first[x];
while i> do begin
too:=edge[i].toward;
if edge[i].flag and chose[too] then begin
chose[too]:=false;
if (match[too]=) or dfs(match[too]) then begin
edge[matche[too]].flag:=true;
matche[too]:=i;
match[too]:=x;
edge[i].flag:=false;
exit(true);
end;
end;
i:=edge[i].next;
end;
exit(false);
end; procedure work;
var
i,j,boy,girl:longint;
begin
for i:= to n do begin
fillchar(chose,sizeof(chose),true);
dfs(edge[e[i]].from);
end;
//for i:= to n do writeln(match[i<<]);
for i:= to n do begin
fillchar(chose,sizeof(chose),true);
j:=e[i];
if edge[j].flag then begin
writeln('Unsafe');
continue;
end;
boy:=edge[j].toward;
girl:=edge[j].from;
match[boy]:=;
if not dfs(girl) then begin
match[boy]:=girl;
matche[boy]:=j;
writeln('Safe');
end
else writeln('Unsafe');
end;
end; begin
into;
work;
end.
bzoj 2140: 稳定婚姻 (二分图)的更多相关文章
- BZOJ 2140 稳定婚姻 ——二分图
		论二分图的可行边与必须边. 考虑用dinic增广之后的图,一些是必要的割边,一些是可行的割边. 我们首先求出一组可行的最大匹配,那么这些变都是可行的. 然后我们求一遍强连通分量. 如果 scc[u]! ... 
- BZOJ 2140 稳定婚姻
		2140: 稳定婚姻 Description 我国的离婚率连续7年上升,今年的头两季,平均每天有近5000对夫妇离婚,大城市的离婚率上升最快,有研究婚姻问题的专家认为,是与简化离婚手续有关. 25岁的 ... 
- 2140: 稳定婚姻 - BZOJ
		Description 我国的离婚率连续7年上升,今年的头两季,平均每天有近5000对夫妇离婚,大城市的离婚率上升最快,有研究婚姻问题的专家认为,是与简化离婚手续有关. 25岁的姗姗和男友谈恋爱半年就 ... 
- 【BZOJ】2140 稳定婚姻
		[解析]Hash,离散化.Tarjan [分析] 对于每一个名字.首先离散化成编号. 用hash或者其它,反正不要最主要的即可了.否则O(N^2L)会爆掉. 然后请參考:http://www.cnbl ... 
- BZOJ2140: 稳定婚姻
		题解: 题意就是求二分图的必须边. 我们有结论: 在残量网络上跑tarjan,对于一条边(u,v) 如果该边满流||scc[u]==scc[v],那么该边是可行边. 因为如果scc[u]==scc[v ... 
- BZOJ2140: 稳定婚姻(tarjan解决稳定婚姻问题)
		2140: 稳定婚姻 Time Limit: 2 Sec Memory Limit: 259 MBSubmit: 1321 Solved: 652[Submit][Status][Discuss] ... 
- 【稳定婚姻问题】【HDU1435】【Stable Match】
		2015/7/1 19:48 题意:给一个带权二分图 求稳定匹配 稳定的意义是对于某2个匹配,比如,( a ---- 1) ,(b----2) , 如果 (a,2)<(a,1) 且(2,a)& ... 
- 洛谷 P1407 [国家集训队]稳定婚姻 解题报告
		P1407 [国家集训队]稳定婚姻 题目描述 我国的离婚率连续7年上升,今年的头两季,平均每天有近5000对夫妇离婚,大城市的离婚率上升最快,有研究婚姻问题的专家认为,是与简化离婚手续有关. 25岁的 ... 
- 【bzoj2140】: 稳定婚姻 图论-tarjan
		[bzoj2140]: 稳定婚姻 哎..都是模板题.. 一眼看过去 哇 二分图哎 然后发现好像并不能匈牙利算法 自己xjb画两张图,发现二分图左向右连配偶的边,然后右向左连交往过的边 然后如果Bi G ... 
随机推荐
- linux (rm指令) 及误删除解决
			今天在群里看见这一幕: 看到这儿,我们学习一下 这个RM指令 rm命令可以删除一个目录中的一个或多个文件或目录,也可以将某个目录及其下属的所有文件及其子目录均删除掉.对于链接文件,只是删除整个链接文件 ... 
- CLR via #C读书笔记三:基元类型、引用类型和值类型
			1.一些开发人员说应用程序在32位操作系统上运行,int代表32位整数:在64位操作系统上运行,int代表64位整数.这个说法是完全错误的.C#的int始终映射到System.Int32,所以不管在什 ... 
- Android Test和Logcat
			一 测试相关概念 是否有源码 黑盒测试: 测试工具 白盒测试: 对所有的源码特别熟悉 对特定的代码进行测试 都是编程 时间 单元测试(程序员) 模块测试 集成测试 系统测试 回归测试(改bug) 压力 ... 
- Java 输出对象为字符串 工具类
			public static String reflectionToString(Object o){ if(o == null) return StringUtils.EMPTY; StringBui ... 
- 孤荷凌寒自学python第七十九天开始写Python的第一个爬虫9并使用pydocx模块将结果写入word文档
			孤荷凌寒自学python第七十九天开始写Python的第一个爬虫9 (完整学习过程屏幕记录视频地址在文末) 今天在上一天的基础上继续完成对我的第一个代码程序的书写. 到今天终于完成了对docx模块针对 ... 
- 基于深度学习的中文语音识别系统框架(pluse)
			目录 声学模型 GRU-CTC DFCNN DFSMN 语言模型 n-gram CBHG 数据集 本文搭建一个完整的中文语音识别系统,包括声学模型和语言模型,能够将输入的音频信号识别为汉字. 声学模型 ... 
- UVa 1225 - Digit Counting - ACM/ICPC Danang 2007 解题报告 - C语言
			1.题目大意 把前n$(n\le 10000)$个整数顺次写在一起:12345678910111213……计算0~9各出现了多少次. 2.思路 第一想法是打表,然而觉得稍微有点暴力.不过暂时没有想到更 ... 
- Java静态方法,静态变量,初始化顺序
			1. 静态方法: 成员变量分为实例变量和静态变量.其中实例变量属于某一个具体的实例,必须在类实例化后才真正存在,不同的对象拥有不同的实例变量.而静态变量被该类所有的对象公有(相当于全局变量),不需要实 ... 
- 面试中要注意的 3 个 JavaScript 问题
			JavaScript 是 所有现代浏览器 的官方语言.因此,各种语言的开发者面试中都会遇到 JavaScript 问题. 本文不讲最新的 JavaScript 库,通用开发实践,或任何新的 ES6 函 ... 
- 找bug——加分作业
			bug1:while循环中的*des++ =*src++; 不能这么写吧... bug2:maxSize没有定义 暂时看到这么多 
