【C002】50229234海岛帝国:独立之战【难度C】——————————————————————————————————————————————————————————————————————————

【题目要求】

恐怖分子多年来一直如饥似渴地渴求“药师傅”帝国,但是,“里脊肉”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 与 WXJ 出品

【试题分析】

这道题中牵扯到了一个关于割点的问题,割点指的是在一个无向连通图中,如果删除某个顶点后,图不再连通,我们称这样的顶点为割点,所以说我们这道题可以抽象成求割点。

那么割点如何求呢?我们很容易就能想到依次删除每个节点再进行广搜,判断是否连通。但这个算法的时间复杂度为O(N(N+M))。有没有更简单的方法呢?

答案是有的,我们在遍历的时候一定会遇到割点(废话废话废话,作者傻×),关键是如何认定一个顶点是割点。假设我们在深搜时遇到了k点,此时图被分成了两部分。一部分是被访问过的,一部分是没被访问过的。如果k是割点,那么剩下的没有被访问过的点中至少会有一个点在不经过k点的情况下,是无论如何再也回不到已访问过的点了,我们只需要找出这个点就行,对于怎么找这里就不在赘述,看下面的代码。

【代码】

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

转载于:https://www.cnblogs.com/lijiaxin-blog-cpp/p/5602542.html

首师大附中互测题:50229234海岛帝国:独立之战【C002】相关推荐

  1. 首师大附中互测题:99999999海岛帝国后传:算法大会【D001】

    [D001]99999999海岛帝国后传:算法大会[难度:D] -------------------------------------------------------------------- ...

  2. 首师大附中互测题:LJX的校园:入学典礼【C003】

    [C003]LJX的校园:入学典礼[难度C]------------------------------------------------------------------------------ ...

  3. 首师大附中互测题:50136142WXY的坑爹百度地图【B006】(可以喝的超大桶水)

    [B006]50136142WXY的坑爹百度地图[难度B]----------------------------------------------------------------------- ...

  4. 首师大附中OJ系统 0004 我们的社团

    我们的社团 这里可以快速跳转: 试题要求 试题分析 试题代码 试题要求 难度级别:A: 运行时间限制:1000ms: 运行空间限制:256000KB: 代码长度限制:2000000B 试题描述 首师大 ...

  5. 首师大附中集训第二十天综合模测

    正题 第一题:伟大的航线 穿越河流是危险的,有船的河流就更加危险,这反而激发了Noder挑战极限的热情.然而Noder是一个 理智的人,他会想办法避开那些真正的危险. 河流在东西方向有几个平行的航道. ...

  6. 首师大附中集训第十三天综合模测

    正题 第一题:信仰圣光 精灵王国的每一名精灵都曾是圣光的信徒,在圣光的沐浴下歌颂祈福. 然而百年前的那场浩劫摧毁了 Bzeroth 大陆与神界的通道,同时将大陆打碎分散到了 不同的次元里. 百年后神界 ...

  7. 首师大附中集训第十一天:OI炼金术

    正题 今天给我们上课的老师很有趣. 交给我们不只是一些题,还有一些题的入手方法,如何把题面转化为题解才是最重要的. OI选手经常遇到的痛点 看了题解之后:啊,好简单,我咋没想到呢? 这题我想出来了,但 ...

  8. 首师大附中集训第四天:杂

    正题 今天讲的是一些杂题 一开始的是一些搜索. 1.长度为N的数列,已知N个前缀和以及N个后缀和共2N个数打乱后的结果,已知数列中每个数的范围是不超过500的整数,求原数列,存在多组时间求字典序最小的 ...

  9. 首师大附中OJ系统 0012 求滑动距离

    求滑动距离 这里可以快速跳转: 试题要求 试题分析 试题代码 试题要求 难度级别:A: 运行时间限制:1000ms: 运行空间限制:51200KB: 代码长度限制:2000000B 试题描述 一架雪橇 ...

最新文章

  1. AI 技术实力图谱全解析!2018 中国 AI 开发者大会重磅来袭
  2. jzoj6001. 【PKUWC2019模拟2019.1.15】Mines (tarjan)
  3. 案例:用JS实现放大镜特效
  4. Elasticsearch本地 docker-compose 安装
  5. Flutter开发之HTTP网络请求:HttpClient(26)
  6. 【Jmeter篇】jmeter+Ant+Jenkins接口自动化测试集成之报告优化(三)
  7. (zhuan) Building Convolutional Neural Networks with Tensorflow
  8. 【flink】Flink常见Checkpoint超时问题排查思路
  9. 彩色粉末粉尘喷溅高清素材,让热烈气氛烘托到极致
  10. 《Python程序设计》在亚马逊京东当当互动出版网淘宝全面上架
  11. image 微信小程序flex_第三天学习微信小程序开发总结
  12. 蓝凌ekp开发_蓝凌 EKP 集成插件
  13. day_05 显示字符A
  14. linux sh 按键精灵,按键精灵脚本代码教程
  15. VMware Workstation 16.2 Pro for Windows SLIC 2.6 Unlocker
  16. 仿layui风格漂亮easyui主题皮肤美化
  17. 如何高效填写软件测试缺陷报告?(送缺陷报告模板)
  18. 二进制码和格雷码转换问题
  19. android textview 字体边框,为TextView添加一个边框的几种办法
  20. 重启网络显示:Device eth0 does not seem to be present,delaying initialization.

热门文章

  1. Spring Boot 实现苹果支付同步验证
  2. Sencha Touch中 xclass和xtype区别
  3. php wss发送,HTTPS 连接WSS问题
  4. 成功解决需要Xmanager软件来处理X11转发需求
  5. Mark : 什么是ERC20,ERC721?两者的区别是什么?
  6. Java中的高级“过滤器“Stream流
  7. php 银行支付通道_PHP银联在线支付接口的开发实例
  8. Linux用户及权限管理练习
  9. python之getattr()函数和importlib库的使用
  10. TA进阶实例34(Unreal制作水晶星光效果)