Friendship

Time Limit: 2000MS Memory Limit: 20000K

Total Submissions: 9824 Accepted: 2720

Description

In modern society, each person has his own friends. Since all the people are very busy, they communicate with each other only by phone. You can assume that people A can keep in touch with people B, only if

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

The first line of the input contains three integers N (2<=N<=200), S and T ( 1 <= S, T <= N , and S is not equal to T).Each of the following N lines contains N integers. If i knows j’s number, then the j-th number in the (i+1)-th line will be 1, otherwise the number will be 0.

You can assume that the number of 1s will not exceed 5000 in the input.

Output

If there is no way to make A lose touch with B, print “NO ANSWER!” in a single line. Otherwise, the first line contains a single number t, which is the minimal number you have got, and if t is not zero, the second line is needed, which contains t integers in ascending order that indicate the number of people who meet bad things. The integers are separated by a single space.

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

Source

POJ Monthly

题意:给不同的人之间的联系,问至少有多少人遇到糟糕的事情会使S,T之间断开联系;

这个题需要拆点,将点拆成(i,i+N),之间的容量为一,遇到糟糕的事情就是自己与自己失去联系,通过最大流可以判断最小割,然后枚举点找字典序最最小的.

#include <map>
#include <cmath>
#include <queue>
#include <stack>
#include <string>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
const int INF =0x3f3f3f3f;
const double eps =1e-8;
const int Max =3000;
struct node
{
int cap;
int flow;
} Map[500][500];
int Set[500];
int Du[555];
bool vis[555];
int S,T,N;
int s,t;
void AddEdge(int u,int v,int w)
{
Map[u][v].cap = w;
}
bool BFS()
{
memset(Du,0,sizeof(Du));
memset(vis,false,sizeof(vis));
queue<int>Q;
Du[s]=1;
vis[s]=true;
Q.push(s);
while(!Q.empty())
{
int u=Q.front();
Q.pop();
for(int i=0; i<=t; i++)
{
if(!vis[i]&&Map[u][i].cap>Map[u][i].flow)
{
vis[i]=true;
Du[i]=Du[u]+1;
Q.push(i);
}
}
}
return vis[t];
}
int DFS(int star,int num)
{
if(star==t)
{
return num;
}
int a=0;
int ant;
for(int i=0; i<=t; i++)
{
if(Du[i]==Du[star]+1&&Map[star][i].cap>Map[star][i].flow)
{
if(ant=DFS(i,min(num,Map[star][i].cap-Map[star][i].flow)))
{
Map[star][i].flow+=ant;
Map[i][star].flow-=ant;
num-=ant;
a+=ant;
if(num==0)
{
break;
}
}
}
}
return a;
}
void Dinic()
{
int ans=0;
while(BFS())
{
ans+=DFS(0,INF);
}
printf("%d\n",ans);
if(!ans)
{
return ;
}
int cut=0;
int tmp=ans;
for(int i=1; i<=N&&tmp; i++)
{
if(i==S||i==T)
{
continue;
}
if(Map[i][i+N].flow==0)
{
continue;
}
Map[i][i+N].cap=0;
for(int a=1; a<=t; a++)
{
for(int b=1; b<=t; b++)
{
Map[a][b].flow=0;
}
}
ans=0;
while(BFS())
{
ans+=DFS(0,INF);
}
if(ans!=tmp)
{
Set[cut++]=i;
tmp=ans;
}
else
{
Map[i][i+N].cap=1;
}
}
for(int i=0; i<cut; i++)
{
if(i)
{
printf(" ");
}
printf("%d",Set[i]);
}
printf("\n");
}
int main()
{
int data;
while(~scanf("%d %d %d",&N,&S,&T))
{
memset(Map,0,sizeof(Map));
s=0;
t=N*2+1;
AddEdge(s,S,INF);
AddEdge(T+N,t,INF);
for(int i=1; i<=N; i++)
{
AddEdge(i,i+N,1);
for(int j=1; j<=N; j++)
{
scanf("%d",&data);
if(data)
{
AddEdge(i+N,j,INF);
}
}
}
AddEdge(S,S+N,INF);
AddEdge(T,T+N,INF);
if(!Map[S+N][T].cap)
{ Dinic();
}
else
{
printf("NO ANSWER!\n");
}
}
return 0;
}

Friendship的更多相关文章

  1. POJ 1815 Friendship

    Friendship Time Limit: 2000MS   Memory Limit: 20000K Total Submissions: 10626   Accepted: 2949 Descr ...

  2. HDU 5578 Friendship of Frog 水题

    Friendship of Frog Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.ph ...

  3. WordPress BuddyPress Extended Friendship Request插件跨站脚本漏洞

    漏洞名称: WordPress BuddyPress Extended Friendship Request插件跨站脚本漏洞 CNNVD编号: CNNVD-201307-609 发布时间: 2013- ...

  4. Friendship of Frog(水题)

    Friendship of Frog Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Other ...

  5. Codeforces 791B Bear and Friendship Condition(DFS,有向图)

    B. Bear and Friendship Condition time limit per test:1 second memory limit per test:256 megabytes in ...

  6. codeforces round #405 B. Bear and Friendship Condition

    B. Bear and Friendship Condition time limit per test 1 second memory limit per test 256 megabytes in ...

  7. Bear and Friendship Condition-HZUN寒假集训

    Bear and Friendship Condition time limit per test 1 secondmemory limit per test 256 megabytesinput s ...

  8. POJ 1815 Friendship (Dinic)

    Friendship Time Limit: 2000MS   Memory Limit: 20000K Total Submissions: 11429   Accepted: 3173 Descr ...

  9. 8. American Friendship 美国式的友谊

    8. American Friendship 美国式的友谊 (1) Americans usually consider themselves a friendly people.Their frie ...

随机推荐

  1. jvm内存设置

    JVM有很多个内存管理命令,总体而言,分为两类: 1.-X开头的管理命令:这些选项在JDK升级时不会通知修改: 2.-XX开头的管理命令:这些选项不够稳定,所以建议少用. JVM参数的含义: 参数名称 ...

  2. [转]数据库高可用架构(MySQL、Oracle、MongoDB、Redis)

    一.MySQL   MySQL小型高可用架构 方案:MySQL双主.主从 + Keepalived主从自动切换 服务器资源:两台PC Server 优点:架构简单,节省资源 缺点:无法线性扩展,主从失 ...

  3. .NET: C#: Attribute

    ref: http://www.uml.org.cn/net/200810135.asp ref: http://blog.csdn.net/okvee/article/details/2610349 ...

  4. ofbiz进击 第六节。 --OFBiz配置之[widget.properties] 配置属性的分析

    配置内容分析如下 # -- 定义上下文使用者 -- security.context =default # -- 定义密码限制长度最小值 -- password.length.min =5 # -- ...

  5. ThinkPHP 中实现 Rewrite 模式

    ThinkPHP中默认的URL地址是形如这样的:http://localhost/Myapp/index.php/Index/index/ Myapp是我的项目文件名,默认的访问地址是上面这样的.为了 ...

  6. centos dhcp网络设置

    CentOS 网络设置修改   一.CentOS 修改IP地址 修改对应网卡的IP地址的配置文件# vi /etc/sysconfig/network-scripts/ifcfg-eth0 修改以下内 ...

  7. Android 仿土巴兔选择效果

    1,前两天在群里看到有人在讨论土巴兔的选择装修风格的效果,自己也想实现,果断百度一下,有些好的文章,就花了些时间来分析了下,先看看别人土巴兔原装的功能 2,可以看到,基本上可以使用一个vviewpag ...

  8. paper 25 :SVM支持向量机是什么意思?

    转载来源:https://www.zhihu.com/question/21094489 作者:余洋链接:https://www.zhihu.com/question/21094489/answer/ ...

  9. BJFU 1009

    描述 现在社会上的抽奖活动简直是太多了.前段时间中国联通就举办了一个很无聊的抽奖活动,规则是每人可以向中国联通的短信系统发送一个实数,系统每天会从这些数字中选择一个无重复(就是有且只有一个)且最小的数 ...

  10. Deep Learning 深度学习 学习教程网站集锦

    http://blog.sciencenet.cn/blog-517721-852551.html 学习笔记:深度学习是机器学习的突破 2006-2007年,加拿大多伦多大学教授.机器学习领域的泰斗G ...