UESTC_方老师和农场 2015 UESTC Training for Graph Theory<Problem L>

L - 方老师和农场

Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)

Submit Status

方老师重新开了一家农场,农场一共有N个节点和M条双向边,但是有一个很大的问题就是有比如一个农场A到达农场B只有一条路径,问至少添加多少条边使得任意两个农场之间的路径多于一条。

Input

  • 多组数据,EOF结束。
  • 第1行:N和M。
  • 第2到第M+1行:每一行2个数Ui和Vi,表示Ui到Vi之间有一条边。

Output

一行一个数表示至少需要添加多少条边。

Sample input and output

Sample Input Sample Output
7 7
1 2
2 3
3 4
2 5
4 5
5 6
5 7
2

Hint

N≤100000,M≤100000

解题思路:

我们先考虑原图连通的情况

首先跑一遍图,求出所有的桥,之后跑出边双连通分量数目.

将边双连通分量看成一个点.

之后我们考虑整个图,必然成了一棵树.

证明:

假设将边双连通分量看成一个点后图不是树,必然存在两个儿子之间连有边,这样就构成了边双连通,显然不合法,故命题正确.

<B,C>之间不可能有边,否则构成了边双连通.

之后我们将问题转换为了树上至少连多少条边,使得树上任意两点的路径条数多于两条?

这样问题就很容易解了.

设树上的叶子有 N 个

If N ∈ (2 * k ) , ans = N / 2;

Else ans = ( N + 1 ) / 2

综合下得 ans = (N + 1 ) / 2;

为什么这样是对的呢?,我们将树上非叶的结点看成一个大圆圈,之后叶子,两两配对(找不到就自己和自己配),配对的顺序是第 x 个,和第 n – x + 1个,如图:

之后我们考虑,若原图不连通,如何求解?

还是看成大圆圈加几个根,把所有的叶子数加起来当成 N 就可以了.

这里有点要注意,我们给一旦连了一条边,其实我们就等于给大圆圈连了一条边了

<夜深了,就不证明了>

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <vector>
#include <set>
#define pb push_back

//#define localtest

using namespace std;
const int maxn = 1e5 + 50;
int n,m,new_time[maxn],low[maxn],T,tot,degree[maxn],number[maxn];
bool use[maxn];

typedef pair<int,int> Etype;
set<Etype>spj;

typedef struct Edge
{
  int v,isbridge;
  Edge(const int &v)
   {
         this->v = v;
         isbridge = 0;
   }
};

vector<Edge>E[maxn];

int tarjan_dfs(int cur,int pre)
{
   new_time[cur] = low[cur] = T++;
   for(int i = 0 ; i < E[cur].size() ; ++ i)
    {
         int nextnode = E[cur][i].v;
         if (!new_time[nextnode]) //树边
          {
               int lowv = tarjan_dfs(nextnode,cur);
               if (lowv > new_time[cur])
                {
                    E[cur][i].isbridge = 1;
                    #ifdef localtest
                     cout << cur << " - " << nextnode << " is a bridge " << endl;
                    #endif
                    use[cur] = true , use[nextnode] = true;
                 }
                low[cur] = min(low[cur],lowv); // updata
          }
        else if(new_time[nextnode] < new_time[cur] && nextnode != pre) //反向边
          low[cur] = min(low[cur],low[nextnode]);
    }
  return low[cur];
}

int main(int argc,char *argv[])
{
  while(~scanf("%d%d",&n,&m))
   {
         spj.clear();
         for(int i = 1 ; i <= m ; ++ i)
          {
                int u,v;
                scanf("%d%d",&u,&v);
                if (u > v)
                 swap(u,v);
                Etype temp(u,v);
                if (spj.count(temp))
                 continue;
                else
                 spj.insert(temp);
                E[u].pb(Edge(v)) , E[v].pb(Edge(u));
          }
         memset(new_time,0,sizeof(new_time));
         memset(number,0,sizeof(number));
         memset(use,false,sizeof(use));
         memset(degree,0,sizeof(degree));
         T = 1;
         for(int i = 1 ; i <= n ; ++ i)
          if (!new_time[i])
           tarjan_dfs(i,0); //跑割桥
         for(int i = 1 ; i <= n ; ++ i)
          {
             for(int j = 0 ; j < E[i].size() ; ++ j)
            {
                int nextnode = E[i][j].v;
                if (low[i] != low[nextnode]) //缩点
                 {
                     degree[low[i]] ++ ;
                     degree[low[nextnode]] ++ ;
                 }
            }
       }
      int leaf = 0;
      for(int i = 1 ; i <= n ; ++ i)
       if (degree[i]  == 2)
        leaf++;
      printf("%d\n",(leaf+1)/2);
         for(int i = 1 ; i <= n ; ++ i)
          E[i].clear();
   }
  return 0;
}
时间: 2024-08-02 02:51:01

UESTC_方老师和农场 2015 UESTC Training for Graph Theory<Problem L>的相关文章

UESTC_邱老师的脑残粉 2015 UESTC Training for Graph Theory&lt;Problem D&gt;

D - 邱老师的脑残粉 Time Limit: 12000/4000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 邱老师的粉丝众多,每天邱老师都得面对粉丝们数不尽的邀约,邱老师一个人处理不过来,所以想请你帮忙. 假设某天有N个粉丝想和邱老师约,一旦某个粉丝成功地约上了邱老师,她就会发微博和朋友炫耀.一旦某个粉丝发现微博里有关于邱老师的消息,她都会转发. 如果当天内某个约上邱老师的粉丝发现微

UESTC_秋实大哥带我飞 2015 UESTC Training for Graph Theory&lt;Problem B&gt;

B - 秋实大哥带我飞 Time Limit: 300/100MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 然而题目和题面并没有什么关系. 给出n个点,m条带权无向边,问你从1号点到n号点的最短路中有多少种走法? Input 第一行两个数n,m分别表示点的个数和边的个数. (2≤n≤2000,1≤m≤2000) 接下来m行,每行3个数u,v,w表示u号点到v号点有一条距离为w的边.(1≤u

UESTC_韩爷的情书 2015 UESTC Training for Graph Theory&lt;Problem H&gt;

H - 韩爷的情书 Time Limit: 6000/2000MS (Java/Others)     Memory Limit: 262144/262144KB (Java/Others) Submit Status 某年某月某日,韩爷被妹子表白了\o/ 同时,韩爷收到了来自妹子的情书.在好奇心的驱使下,众人想要一览究竟. 显然,羞涩韩爷是不会把情书直接拿出来的. 假设情书长度为n+2,韩爷从中提取出n个长度为3的连续字符串,分给了n个人. 现在这n个人向你求助,能否帮他们把情书恢复出来. I

UESTC_小panpan学图论 2015 UESTC Training for Graph Theory&lt;Problem J&gt;

J - 小panpan学图论 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 小panpan不会图论,所以图论专题他非常刻苦地学习图论. 今天他认真地学习了萌神的ppt,学习了一下Floyd算法,手持两把锟斤拷的他, 口中疾呼烫烫烫,马上找了到OJ上找了道FLoyd的题: n个点,m边的无向连通图,无重边,无自环,每条边的长度都是1,求任意两点之间的

UESTC_邱老师玩游戏 2015 UESTC Training for Dynamic Programming&lt;Problem G&gt;

G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 邱老师最近在玩一种战略游戏,在一个地图上,有N座城堡,每座城堡都有一定的宝物,在每次游戏中邱老师允许攻克M个城堡并获得里面的宝物. 但由于地理位置原因,有些城堡不能直接攻克,要攻克这些城堡必须先攻克其他某一个特定的城堡.你能帮邱老师算出要获得尽量多的宝物应该攻克哪M个城堡吗? In

UESTC_邱老师看电影 2015 UESTC Training for Dynamic Programming&lt;Problem F&gt;

F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 一天邱老师心血来潮想去看电影,但是邱老师的妹子想去逛街,他们谁也没有办法说服对方,于是准备来玩一个游戏来决定听谁的. 邱老师找来w只白鼠和b只黑鼠,邱老师和妹子轮流从袋子里面抓老鼠,谁先抓到白色老鼠谁就赢. 但是有酱神在旁边捣乱,邱老师每抓一只老鼠出来,酱神就偷偷的也从里面抓一只出

UESTC_邱老师选妹子 2015 UESTC Training for Dynamic Programming&lt;Problem H&gt;

H - 邱老师选妹子 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 邱老师长得帅这是人尽皆知,于是追他的妹子就会很多. 但是你知道,邱老师是一个很专一的人,所以他心里面只能有一个人. 于是他决定从追他的众多妹子里挑选一个出来.于是酱神给邱老师出来一个主意,已知有一些妹子,恰好可以给她们从l到r排号,使得每一个妹子有单独的数字,而正好有r-l+1个妹

UESTC_排名表 2015 UESTC Training for Graph Theory&lt;Problem I&gt;

I - 排名表 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 暑假前集训已经过了一半了,我们将会把当前排名公布出来.但是此刻秋实大哥却心急火燎,因为他不慎把排名删除了. 一共有n个人参加排名,每个人都有一个名次,没有哪两个人的名次是相同的.现在秋实大哥掌握的一些情报,比如Ai的名次要先于Bi.(编号从1开始) 你能帮秋实大哥恢复出排名表吗? Inp

UESTC_传输数据 2015 UESTC Training for Graph Theory&lt;Problem F&gt;

F - 传输数据 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 机房里面有m台电脑,n台网线,每条网线都每秒中最多传送的数据量,现在需要你计算从标号为1的电脑传送数据到编号为m的电脑,问一秒内最多传送多少数据? Input 第1行: 两个用空格分开的整数N(0≤N≤200)和 M(2≤M≤200).N网线的数量,M是电脑的数量. 第二行到第N+1行