危险系数

来源:互联网 发布:阿里云缩写 编辑:程序博客网 时间:2024/04/30 07:30
问题描述

抗日战争时期,冀中平原的地道战曾发挥重要作用。

地道的多个站点间有通道连接,形成了庞大的网络。但也有隐患,当敌人发现了某个站点后,其它站点间可能因此会失去联系。

我们来定义一个危险系数DF(x,y):

对于两个站点x和y (x != y), 如果能找到一个站点z,当z被敌人破坏后,x和y不连通,那么我们称z为关于x,y的关键点。相应的,对于任意一对站点x和y,危险系数DF(x,y)就表示为这两点之间的关键点个数。

本题的任务是:已知网络结构,求两站点之间的危险系数。

输入格式

输入数据第一行包含2个整数n(2 <= n <= 1000), m(0 <= m <= 2000),分别代表站点数,通道数;

接下来m行,每行两个整数 u,v (1 <= u, v <= n; u != v)代表一条通道;

最后1行,两个数u,v,代表询问两点之间的危险系数DF(u, v)。

输出格式
一个整数,如果询问的两点不连通则输出-1.
样例输入
7 6
1 3
2 3
3 4
3 5
4 5
5 6
1 6
样例输出
2

#include "iostream"
#include "vector"
using namespace std;
int n,m;
bool book[1020];
int way[1020];
int begin,end;
vector<int> ve[1020];
int result=0;
int ans[1020];
int sum=0;
bool ok=0;
int len=0;
int main(){
 void dfs(int now);
 int i,a,b;
 cin>>n>>m;
 for(i=0;i<m;i++){
  cin>>a>>b;
    ve[a].push_back(b);
    ve[b].push_back(a);
 }
 for(i=1;i<=n;i++){
   book[i]=0;
   ans[i]=0;
 }
 cin>>begin>>end;
 book[begin]=1;
 dfs(begin);
 if(ok==0)
 cout<<-1;
 else{
  for(i=1;i<=n;i++)
   if(sum==ans[i])
   result++;
   cout<<result-1;
 }
 return 0;
}
void dfs(int now){
 int i;
 if(now==end){
  sum++;
  ok=1;
  for(i=0;i<len;i++)
    ans[way[i]]++;
    return;
 }
 for(i=0;i<ve[now].size();i++){
  if(book[ve[now][i]]!=1){
   book[ve[now][i]]=1;
   way[len++]=ve[now][i];
   dfs(ve[now][i]);
   book[ve[now][i]]=0;
   len--;
  }
 }
}

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 扫地机器人坏了怎么办 孩子思维逻辑差怎么办 喜欢动手打别人怎么办 小孩写作文困难怎么办 2岁儿子打人怎么办 三岁宝宝爱咬人怎么办 幼儿园小孩咬人怎么办 孩子不会动手打人怎么办 小孩子隔奶奶涨怎么办 小孩子戒奶奶涨怎么办 孩子总打别人怎么办 儿童在学校打人怎么办 两岁儿童打人怎么办 孩子哭闹要东西怎么办 高中孩子爱打架怎么办 宝宝性格太弱怎么办 宝宝太老实了怎么办 一岁多宝宝爱打人怎么办 一岁半宝宝爱打人怎么办 两岁半宝宝喜欢打人怎么办 孩子总是挨欺负怎么办 一年级孩子爱打架怎么办 孩子没规矩家长怎么办 小朋友在幼儿园打人怎么办 幼儿园小朋友喜欢打人怎么办 三周岁宝宝爱哭怎么办 2周岁宝宝爱哭怎么办 一个月宝宝爱哭怎么办 2岁宝宝爱哭怎么办 三岁小朋友打人怎么办 一岁半小朋友喜欢打人怎么办 爷爷偏心我该怎么办 冲动型学生老师怎么办 两个宝宝争东西怎么办 2周岁宝宝打人怎么办 小孩幼儿园被打怎么办 小孩喝了润滑油怎么办 孩子被打了怎么办 宝宝吃了指甲油怎么办 孩子掉了深海怎么办 小孩打了别人怎么办