LA 7272 Promotions(dfs)
https://vjudge.net/problem/UVALive-7272
题意:
公司要提拔人,现在有n个人,现在有m条有向边,A->B表示A的表现比B好,也就是如果B晋升了,那么A肯定会晋升。
现在给出【L,R】,计算出晋升L个人时肯定会晋升的人数,晋升R个人时肯定会晋升的人数,还有肯定不可能晋升的人数。
思路:
先说一下计算不可能人数的算法。
这个需要反向建图,我们dfs遍历,假设现在从第i个人开始遍历,遍历得到它的子节点的个数,这就是说如果i晋升的话,他前面的人也都必须要晋升。
如果这个人数大于了限定的晋升人数,那么这个人肯定是不可能晋升的。
剩余两个也是这样分析的,具体参见代码。
#include<iostream>
#include<string>
#include<cstring>
#include<algorithm>
#include<queue>
#include<cstdio>
using namespace std; const int maxn=+; int n, m;
int A,B;
int num; vector<int> g[maxn];
vector<int> r_g[maxn]; int vis[maxn]; void r_dfs (int u)
{
if(vis[u]) return;
vis[u]=;
num++;
for(int i=;i<r_g[u].size();i++)
{
r_dfs(r_g[u][i]);
}
} void dfs (int u)
{
if(vis[u]) return;
vis[u]=;
num++;
for(int i=;i<g[u].size();i++)
{
dfs(g[u][i]);
}
} int main()
{
//freopen("D:\\input.txt", "r", stdin);
while (~scanf("%d%d%d%d",&A, &B, &n, &m))
{
for(int i=;i<n;i++) {g[i].clear();r_g[i].clear();}
for(int i=;i<m;i++)
{
int u,v;
scanf("%d%d",&u,&v);
g[u].push_back(v);
r_g[v].push_back(u);
}
int ans1=,ans2=,ans3=;
for(int i=;i<n;i++)
{
memset(vis,,sizeof(vis));
num=-;
r_dfs(i);
if(num>=B) ans3++;
memset(vis,,sizeof(vis));
num=-;
dfs(i);
if(num>=n-A) ans1++;
if(num>=n-B) ans2++;
}
printf("%d\n%d\n%d\n",ans1,ans2,ans3);
}
return ;
}
LA 7272 Promotions(dfs)的更多相关文章
- LeetCode Subsets II (DFS)
		题意: 给一个集合,有n个可能相同的元素,求出所有的子集(包括空集,但是不能重复). 思路: 看这个就差不多了.LEETCODE SUBSETS (DFS) class Solution { publ ... 
- LeetCode  Subsets (DFS)
		题意: 给一个集合,有n个互不相同的元素,求出所有的子集(包括空集,但是不能重复). 思路: DFS方法:由于集合中的元素是不可能出现相同的,所以不用解决相同的元素而导致重复统计. class Sol ... 
- HDU 2553 N皇后问题(dfs)
		N皇后问题 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Description 在 ... 
- 深搜(DFS)广搜(BFS)详解
		图的深搜与广搜 一.介绍: p { margin-bottom: 0.25cm; direction: ltr; line-height: 120%; text-align: justify; orp ... 
- 【算法导论】图的深度优先搜索遍历(DFS)
		关于图的存储在上一篇文章中已经讲述,在这里不在赘述.下面我们介绍图的深度优先搜索遍历(DFS). 深度优先搜索遍历实在访问了顶点vi后,访问vi的一个邻接点vj:访问vj之后,又访问vj的一个邻接点, ... 
- 深度优先搜索(DFS)与广度优先搜索(BFS)的Java实现
		1.基础部分 在图中实现最基本的操作之一就是搜索从一个指定顶点可以到达哪些顶点,比如从武汉出发的高铁可以到达哪些城市,一些城市可以直达,一些城市不能直达.现在有一份全国高铁模拟图,要从某个城市(顶点) ... 
- 深度优先搜索(DFS)和广度优先搜索(BFS)
		深度优先搜索(DFS) 广度优先搜索(BFS) 1.介绍 广度优先搜索(BFS)是图的另一种遍历方式,与DFS相对,是以广度优先进行搜索.简言之就是先访问图的顶点,然后广度优先访问其邻接点,然后再依次 ... 
- 图的 储存 深度优先(DFS)广度优先(BFS)遍历
		图遍历的概念: 从图中某顶点出发访遍图中每个顶点,且每个顶点仅访问一次,此过程称为图的遍历(Traversing Graph).图的遍历算法是求解图的连通性问题.拓扑排序和求关键路径等算法的基础.图的 ... 
- 搜索——深度优先搜索(DFS)
		设想我们现在身处一个巨大的迷宫中,我们只能自己想办法走出去,下面是一种看上去很盲目但实际上会很有效的方法. 以当前所在位置为起点,沿着一条路向前走,当碰到岔道口时,选择其中一个岔路前进.如果选择的这个 ... 
随机推荐
- csv的文件excel打开长数字后面位变0的解决方法
			对于有大数字的CSV文件,应使用导入,而不是打开.这里以Excel2010为例,其它版本也可以参照: 打开Excel,此时Excel内为空白文档 点击工具栏中的[数据]→[自文本] 在“导入文本文件” ... 
- python基础-第十三篇-13.1web框架本质
			基础与概念 众所周知,对于所有的web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端 web框架分两类:一类是包括socket和业务逻辑(tornado),另一 ... 
- 解决线上Tomcat启动慢
			vim /application/jdk/jre/lib/security/java.security # securerandom.source=file:/dev/randomsecurerand ... 
- centos下apache安装
			./configure --prefix=/usr/local/apache2 --enable-so --enable-proxy --enable-proxy-connect --enable-p ... 
- 文字识别的google的库 tesseract
			https://github.com/tesseract-ocr/tesseract https://github.com/tesseract-ocr/tessdata 字体识 ... 
- mysql5.7新特性探究
			一.MySql5.7增加的特性 1.MySql服务方面新特性 1) 初始化方式改变 MySql5.7之前版本初始化方式: scripts/mysql_install_db MySql5.7版本初始化方 ... 
- 从原型链看DOM--Comment,CDATASection,DocumentType,DocumentFragment,Attr类型
			这次总结的是剩下的这些DOM类型节点,可能你见过却不经常使用但是了解一下总是好的,可以加深对DOM体系的整体理解~.本篇要介绍的是Comment,CDATASection,DocumentType,D ... 
- @JsonFormat与@DateTimeFormat注解的使用
			背景:从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了 ... 
- lnmp的环境的安装和搭建
			上次中,记录了lamp的环境的搭建和安装,这一次说一下lnmp环境的安装和搭建,下面是详细的安装步骤: 一. 先是Mysql的安装步骤,其实和上次的一样: ): 编译安装MySQL +-------- ... 
- (转)extern关键字两种场景的使用
			第一种场景 -- extern extern关键字的作用是声明变量和函数为外部链接,即该变量或函数名在其它文件中可见.用其声明的变量或函数应该在别的文件或同一文件的其它地方定义. 例如语句:exter ... 
