POJ 1815 Friendship (Dinic)
| Time Limit: 2000MS | Memory Limit: 20000K | |
| Total Submissions: 11429 | Accepted: 3173 |
Description
1. A knows B's phone number, or
2. A knows people C's phone number and C can keep in touch with B.
It's assured that if people A knows people B's number, B will also know A's number.
Sometimes, someone may meet something bad which makes him lose touch with all the others. For example, he may lose his phone number book and change his phone number at the same time.
In this problem, you will know the relations between every two among N people. To make it easy, we number these N people by 1,2,...,N. Given two special people with the number S and T, when some people meet bad things, S may lose touch with T. Your job is to compute the minimal number of people that can make this situation happen. It is supposed that bad thing will never happen on S or T.
Input
You can assume that the number of 1s will not exceed 5000 in the input.
Output
If there is more than one solution, we give every solution a score, and output the solution with the minimal score. We can compute the score of a solution in the following way: assume a solution is A1, A2, ..., At (1 <= A1 < A2 <...< At <=N ), the score will be (A1-1)*N^t+(A2-1)*N^(t-1)+...+(At-1)*N. The input will assure that there won't be two solutions with the minimal score.
Sample Input
3 1 3
1 1 0
1 1 1
0 1 1
Sample Output
1
2
思路:
感谢llw大佬的神奇优化!!!!
耗时两天,终于AC了,总算是证明了自己的算法没有错误。
网上遍地都是拆点的题解,奈何我实在是太弱了,弱到无法想象的地步,实在是看不懂拆点应该要怎么拆,所以我被逼无奈选择了暴力。
那就是,限制一次dfs只能跑出容量为1的流,并将这条流上的所有点标记为不可用,直到一次Dinic结束。
以此取代拆点的操作,是完全可行的,其他的操作都大体相同
终于终于,体会到了AC的快乐,看着题解写出来的题,渐渐地成为了我自闭的根源
代码
邻接矩阵
#include<iostream>
#include<cstring>
#include<queue>
#include<cstdio>
using namespace std;
int mp[300][300];
int n,s,t;
const int inf = 2100000000;
int vis[400],num[400];
bool book[400]; struct edge
{
int u,v,next,w;
}e[400010];
int Head[400010],cur;
int ans[400010]; void add(int x,int y)
{ e[cur].u=x;
e[cur].v=y;
e[cur].next=Head[x];
e[cur].w=1;
Head[x]=cur;
cur++;
e[cur].u=y;
e[cur].v=x;
e[cur].next=Head[y];
e[cur].w=0;
Head[y]=cur;
cur++;
} bool bfs()
{
memset(vis,0,sizeof(vis));
for(int i=1;i<=n;i++){
num[i]=Head[i];
}
vis[s]=1;
queue<int>q;
q.push(s);
int r=0;
while(!q.empty()){
int u=q.front();
q.pop();
int k=Head[u];
while(k!=-1){
if(!book[e[k].v]&&!vis[e[k].v]&&e[k].w){
vis[e[k].v]=vis[u]+1;
q.push(e[k].v);
}
k=e[k].next;
}
}
return vis[t];
} int dfs(int u)
{
if(u==t){return 1;} int &k=num[u];
while(k!=-1){
if(!book[e[k].v]&&vis[e[k].v]==vis[u]+1&&e[k].w){
int d=dfs(e[k].v);
e[k].w-=d;
e[k^1].w+=d;
if(d>0){book[u]=true;return 1;}
}
k=e[k].next;
}
return 0;
} void build()
{
cur=0;
memset(Head,-1,sizeof(Head));
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(mp[i][j]) add(i,j);
}
}
} int Dinic(int y)
{
memset(book,0,sizeof(book));
book[y]=1;
int ans=0;
while(bfs()){
int f;
while((f=dfs(s))>0){//llw大佬太强了orz orz orz
ans+=f;
}
}
return ans;
} inline void rebuild(int tt)
{
for(int i=0;i<=cur;i+=2){
if(e[i].v==tt||e[i].u==tt){e[i].w=e[i^1].w=0;}
else if(e[i^1].w!=0){
e[i].w=1;
e[i^1].w=0;
}
} }
int main()
{
scanf("%d%d%d",&n,&s,&t);
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
scanf("%d",&mp[i][j]);
}
}
if(mp[s][t]==1){printf("NO ANSWER!\n");return 0;}
build();
int maxx=Dinic(0);
rebuild(0);
int num=0;
for(int i=1;i<=n;i++){
if(i==s||i==t){continue;}
int y=Dinic(i);
if(y<maxx){
ans[++num]=i;
maxx=y;
if(maxx==0){break;}
rebuild(i);
}
else rebuild(0);
}
if(num==0){printf("0\n");return 0;}
printf("%d\n",num);
for(int i=1;i<=num;i++){
if(i!=1){printf(" ");}
printf("%d",ans[i]);
}
printf("\n");
}
POJ 1815 Friendship (Dinic)的更多相关文章
- POJ 1815 Friendship (Dinic 最小割)
Friendship Time Limit: 2000MS Memory Limit: 20000K Total Submissions: 8025 Accepted: 2224 Descri ...
- POJ 1815 Friendship(字典序最小的最小割)
Friendship Time Limit: 2000MS Memory Limit: 20000K Total Submissions: 10744 Accepted: 2984 Descr ...
- POJ 1815 Friendship(最大流最小割の字典序割点集)
Description In modern society, each person has his own friends. Since all the people are very busy, ...
- POJ - 1815 Friendship (最小点割集)
(点击此处查看原题) 题目分析 题意:有n个人,编号记为1~n,n个人之间可能有人可以互相联系,如果A能和B联系,那么至少满足这两种情况之一:(1)A知道B的电话(2)A可以和C联系,并且C可以和B联 ...
- POJ 1815 Friendship(最小割+字典序输出割点)
http://poj.org/problem?id=1815 题意: 在现代社会,每个人都有自己的朋友.由于每个人都很忙,他们只通过电话联系.你可以假定A可以和B保持联系,当且仅当:①A知道B的电话号 ...
- POJ 3281 Dining (网络流)
POJ 3281 Dining (网络流) Description Cows are such finicky eaters. Each cow has a preference for certai ...
- POJ 2431 Expedition(探险)
POJ 2431 Expedition(探险) Time Limit: 1000MS Memory Limit: 65536K [Description] [题目描述] A group of co ...
- POJ 3414 Pots(罐子)
POJ 3414 Pots(罐子) Time Limit: 1000MS Memory Limit: 65536K Description - 题目描述 You are given two po ...
- POJ 1847 Tram (最短路径)
POJ 1847 Tram (最短路径) Description Tram network in Zagreb consists of a number of intersections and ra ...
随机推荐
- SSM+shiro及相关插件的整合maven所有依赖,详细注释版,自用,持续更新
整合了SSM+shiro框架,slf4j+logback日志,及一些好用的插件PageHelper,mybatis-generator,Lombok,fastjson等等 <?xml versi ...
- 四、K8S
一.查看日志 journalctl -xeu kubelet
- vue实例相关
第一种方法要比第二种更省事 if (!row.alert_at) return; if(row.alert_at){ } else { } v-for="todo in list" ...
- vim的几个常用操作
现在很少会有人用vim来写代码,所以vim更常用在server上面编辑配置文件或者少量代码编辑: vim操作命令非常之多,如果仅用作一个配置文件的编辑器,掌握几个常用的操作就够了: 常用的操作其实就是 ...
- 用MyEclipse自带工具生成WebService客户端代码
本文章主要是介绍如何利用已经发布了的Webservice的wsdl来自动生成java的客户端代码.注意:本方法需要你采用的java版本是1.5或者以上的版本,采用MyEclipse来自动生成代码. w ...
- Nginx 4层反向代理
L112 是基于TCP POST_ACCEPT阶段 在建立连接后所做的事情 PREACCESS阶段 limit_conn 限流 与HTTP类似 ACCESS阶段 类似HTTP模块用于控制访问权限 S ...
- Spring MVC 使用介绍(三)—— Controller接口控制器
一.概述 Controller接口类图如下,其中,BaseCommandController已从Spring 4移除 基于继承Controller接口的方式已经不推荐使用,仅供学习参考 二.基于Con ...
- ZIP压缩包加密破解
python多线程破解zip文件,废话不多说直接上代码 # -*- coding: UTF-8 -*- #使用多线程和接受参数的形式去破解指定的zip文件 #python3 zip_file_cack ...
- [洛谷P1730] 最小密度路径
类型:Floyd 传送门:>Here< 题意:定义一条路径密度 = 该路径长度 / 边数.给出一张$DAG$,现有$Q$次询问,每次给出$X,Y$,问$X,Y$的最小密度路径($N \le ...
- 【BZOJ3456】轩辕朗的城市规划 无向连通图计数 CDQ分治 FFT 多项式求逆 多项式ln
题解 分治FFT 设\(f_i\)为\(i\)个点组成的无向图个数,\(g_i\)为\(i\)个点组成的无向连通图个数 经过简单的推导(枚举\(1\)所在的连通块大小),有: \[ f_i=2^{\f ...