50229234海岛帝国:独立之战

【试题描述】

恐怖分子多年来一直如饥似渴地渴求“药师傅”帝国,但是,“里脊肉”BANNIE时刻在守护着这一方水土。从而使帝国日益强大。如今,BANNIE由于在 “牡丹3”里没有镜头,自暴自弃。于是,恐怖分子国正式向“药师傅”帝国正式开战,YSF表示战争到底,寸土不让。但由于YSF气数已尽,身体情况日益糟 糕。他派“购物券”WHT为最高指挥官。“太空站站长”LYF为第二指挥官。MZA为国防部部长,率领300万军舰(全是“演员”KLINT赞助的)勇猛 冲锋。随着时光的流逝,WHT发现敌方人数太多,于是,决定先发制人,启用核弹计划及“A N.B”战略计划来阻断敌方的运输补给线,让城市变得孤立无援。核弹也会毁灭城市和连着该城市的所有路。由于战争期间,间谍事件频发,他们拆毁炸弹。而 “药师傅”帝国的资源很无限。从而只有无限枚核弹。WHT经过百般思考,决定启用该计划,先声夺人。所以他想让核弹落在某个城市,从而使恐怖分子的城市连 不在一起。由于能力有限,而且恐怖分子已经占据了绝大部分土地,声势浩大,很难人工计算。所以YSF请你来帮帮WHT,让核弹落在哪个城市能完全让城市不连通?

【输入要求】

* 第一行:两个数:n,m表示有n个城市,m条路
* 接下来m行:两个数:a,b,表示a到b之间有一条路连接。

【输出要求】

* 可能有多个数:表示要炸毁几号城市能到达目的(如果有多个可能把每个可能都输出,用换行分隔)

【输入实例】

6 7
1 4
1 3
4 2
3 2
2 5
2 6
5 6

【输出实例】

2

【其他说明】

n<=9,m<=36
LJX 与 WXJOR 出品

【试题分析】
还是第六感,一上来就会想到以往的暴力,依次删除每一个顶点,然后DFS或BFS来检查图是否连通。如果删除某个节点后,图不再连通,那么刚才删除的点就是一个割点,但是,还有更好的方法吗?当然有。首先,我们可以从图的任意一个点出发(这里默认1号顶点),对此图开始遍历,比如DFS。对一个图进行深度优先遍历就会得到这个图的生成树,但注意:并不一定是最小生成树。在表示该节点在遍历中是第几个被访问到的,这里有一个专有名词,叫“时间截”。我们可以用一个数组NUM来记录每一个节点的时间截。但是,这道题的关键是:如何认定一个顶点是割点呢?假如我们访问到了K点,此时图就会被分成两部分。一部分是已经被访问的了,一部分是还没有被访问过的。如果K是割点,那么剩下的没有被访问过的点中至少有一个点在不经过K的情况下,是无论如何再也回不到已访问过的点了。那么一个连通图就会被K点分割成多个不连通的子图了。

【代码】

 #include<cstdio>
#include<iostream>
using namespace std;
int n,m,e[][],root;
int num[],low[],flag[],index;
void dfs(int cur,int father)
{
int child=;
index++;
num[cur]=index;
low[cur]=index;
for(int i=;i<=n;i++)
{
if(e[cur][i]==)
{
if(num[i]==)
{
child++;
dfs(i,cur);
low[cur]=min(low[cur],low[i]);
if(cur!=root && low[i]>=num[cur]) flag[cur]=;
if(cur==root && child==) flag[cur]=;
}
else if(i!=father) low[cur]=min(low[cur],num[i]);
}
}
return;
}
int main()
{
int x,y;
cin>>n>>m;
for(int i=;i<=n;i++)
{
for(int j=;j<=n;j++)
{
e[i][j]=;
}
}
for(int i=;i<=m;i++)
{
cin>>x>>y;
e[x][y]=;
e[y][x]=;
}
root=;
dfs(,root);
for(int i=;i<=n;i++)
{
if(flag[i]==) cout<<i<<endl;
}
}

【海岛帝国系列赛】No.5 海岛帝国:独立之战的更多相关文章

  1. 首师大附中互测题:50229234海岛帝国:独立之战【C002】

    [C002]50229234海岛帝国:独立之战[难度C]———————————————————————————————————————————————————————————————————————— ...

  2. 【海岛帝国系列赛】No.7 海岛帝国:神圣之日

    50237242海岛帝国:神圣之日 [试题描述] 战争持续九个月了.“购物券”WHT的军队还在跟恐怖分子僵持着.WHT和LJX已经向“公务员”告急,情况不宜乐观.YSF为守护帝国决定打开“够累 的”星 ...

  3. 【海岛帝国系列赛】No.6 海岛帝国:战争前线

    50234237海岛帝国:战争前线 [试题描述] 总指挥官WHT出神入化的计谋虽然大有用武之地,但是聪明的恐怖分子们采取了城市核武器防御系统,可以有效地抵制WHT的炸弹.YSF对此头痛不已,因此 召开 ...

  4. 【海岛帝国系列赛】No.4 海岛帝国:LYF的太空运输站

    50212228海岛帝国:LYF的太空运输站 [试题描述] 最近,“购物券”WHT在“药师傅”帝国资源大会上提出了“SSTS”太空运输站计划.由于恐怖分子前些日子刚猖狂完,炸毁高楼无数,YSF不得不执 ...

  5. 【海岛帝国系列赛】No.3 海岛帝国:运输资源

    海岛帝国:运输资源 [试题描述] YSF考虑到“药师傅”帝国现在资源极度不平均,于是,商讨启用南水北调工程.YZM为首席工程师.现在,YSF由于工作紧张,准备军用物资和民用物资.但他要时时关注运输工程 ...

  6. 【海岛帝国系列赛】No.2 海岛帝国:“落汤鸡”市的黑帮危机

    50200210海岛帝国:“落汤鸡”市的黑帮危机 [试题描述] 近几天,犯罪分子发现“药师傅”帝国的警力约等于0.(请见YSF的海岛帝国)于是开始猖狂了起来.他们选择了依山靠水(农村?)的“落汤鸡”市 ...

  7. 【海岛帝国系列赛】No.1 海岛帝国:诞辰之日

     50111117海岛帝国:诞辰之日 [试题描述] YSF自从上次“被盗投降”完(带着一大堆债)回去以后,YSF对“海盗”怀念至今,他想要建立一个“药师傅”海岛帝国. 今天,他要像“管理部”那样去探寻 ...

  8. 帝国cms7.0忘记后台管理账户用户名密码

    最近刚登陆以前的网站,但是发现自己的后台管理用户名密码已经忘记,于是到帝国cms论坛里面找了一下解决方案,成功解决问题.特此分享一下解决成功经验. 原帖地址:http://bbs.phome.net/ ...

  9. Java开发笔记(四)Java帝国的度量衡

    秦始皇统一中国之后,实行“书同文,车同轨”,把货币和各种度量衡都统一起来,从而缔造了一个秩序井然的帝国.既然统一度量衡是每个帝国都要做的事情,Java帝国也不例外,对于人生地不熟的初学者来说,只有认识 ...

随机推荐

  1. [LeetCode]题解(python):043-Multiply Strings

    题目来源 https://leetcode.com/problems/multiply-strings/ Given two numbers represented as strings, retur ...

  2. jQuery实现隔行变色

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  3. 安装sqlserver2008r2 服务器配置,服务帐户配置出错,提示Sql server服务指定的凭据无效

    win+X 点击运行 重置帐户密码使得sql server2008 的服务帐户名,密码与系统设置的Administrator名与密码一致,则可. 上图中有一项reporting的名字不同,该名字为自动 ...

  4. Selenium2学习-015-WebUI自动化实战实例-013-通过 URL 关闭多余的已开浏览器窗口

    在日常的 WebUI 自动化测试脚本执行的过程中,经常会打开不同的网页,进行相应的操作,此时可能会打开很多的网页,当打开的网页过多时,无效的网页资源对运行脚本的机器造成了过多无效的资源浪费,因而在日常 ...

  5. Sublime用户如何快速高效开发跨平台App

    2015年9月15日,APICloud举办了一周年开源分享会,发布开源插件支持Sublime用户开发跨平台App,APICloud 开源技术负责人周兴海分享了Sublime关于插件方面相关的内容. S ...

  6. javaEE开发案例——购物车

    一.页面 流程:登录页面(login.jsp)——>购物大厅页面(hall.jsp)——>购物车页面(showMyCart.jsp)——>订单页面(myorder.jsp)——> ...

  7. urllib下载文件

    import urllib 1.用urlib.urlretrieve f = urllib.urlretrieve('http://www.baidu.com/img/bdlogo.gif','/tm ...

  8. 数据块损坏(block corruption)

    分为物理损坏和逻辑损坏-物理损坏一般指数据块头部不可以访问.数据块校验值不合法,数据块格式不再是oracle承认的格式-逻辑损坏一般是在物理性结构完整的情况下,数据的内容在含义上不正确,比如保存了不允 ...

  9. Android Log图文详解

    android.util.Log常用的方法有以下5个:Log.v() Log.d() Log.i() Log.w() 以及 Log.e() .根据首字母对应VERBOSE,DEBUG,INFO, WA ...

  10. Java Thread线程控制

    一.线程和进程 进程是处于运行中的程序,具有一定的独立能力,进程是系统进行资源分配和调度的一个独立单位. 进程特征: A.独立性:进程是系统中独立存在的实体,可以拥有自己独立的资源,每个进程都拥有自己 ...