hiho拓扑排序专题 ——第四十八、四十七周
拓扑排序·一
分析:
此题就是求一个有向图中是否存在环。 如存在环则输出"Wrong", 若不存在环, 说明课程安排的合理,输出"Correct"。
题中的提示说的已经十分清楚了。
总的来说就是:
① 找出入度为0的点(说明该点没有前驱),把该点放入集合T中。 把所有从该点出发的边都删除;
② 遍历剩余的点, 找出入度为0 的点, 重复①操作。
③直到不存在入度为0的点。 结束。如果此时集合T中包含所有的点, 那么该图不存在环, 否则存在环。
注意:1、执行操作①时, 在删除边时(u, v),同时更新与其相关点的入度(du[v]--);
2、 在执行操作②时, 需要遍历所有点, 点少的时候可行, 点多的话很容易超时。 所以题目的提示中告诉了一个好办法就是: 执行操作①更新相关点的入度时直接判断一下是否为0, 若为零则入队列。 这样会省很多时间。
如下图例子:
开始点1入度为0, 点1加入集合T, 删除从1出发的边; 更新相关点的入度, 点2、3的入度都变为0了 , 2、3入队列;
再依次对点2、3进行①操作, 2、3加入T, 删除边(2, 4), (3, 4), 此时没有其他点入度为0了, 结束操作, T中未包含所有点, 说明该图中有环;
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std; int t, n, m, sum, du[];
vector<int> vec[]; int ac()
{
queue<int> q;
for(int i = ; i <= n; i++)//遍历一边所有点, 把入度为0的点,全加入队列q中
{
if(du[i] == )
q.push(i);
}
while(!q.empty())
{
int tem = q.front();//在队列中取出一个入度为0的点
q.pop();
sum++;
//把所有从tem出发的边(tem, v)删除并更新du[],
for(int i = ; i < vec[tem].size(); i++)
{
du[vec[tem][i]]--;
if(du[vec[tem][i]] == )//若点vec[tem][i]入度更新后为0, 则入队列
q.push(vec[tem][i]);
}
vec[tem].clear();
}
if(sum == n) return ;
else
return ;
}
int main()
{
cin >> t;
while(t--)
{
scanf("%d%d", &n, &m);
//用vec[]来存边
for(int i = ; i <= n; i++) vec[i].clear();
memset(du, , sizeof(du));//初始化入度, 置为0;
for(int i = ; i <= m; i++)
{
int x, y;
scanf("%d%d", &x, &y);
vec[x].push_back(y); // 加入边
du[y]++; //记录入度
}
sum = ;
int ans = ac();
if(ans == )
printf("Correct\n");
else
printf("Wrong\n");
}
return ;
}
拓扑排序·二
分析:
和上一道差不多, 只是多了一项就是记录每个点的病毒数。 每个点的病毒数 = 自身病毒数 + 所有能够达到它的节点病毒数之和( 就是所有它前驱点的病毒数的和)。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string.h>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std;
const int mod = ;
int n, m, k, sum, virus[], du[];
vector<int> vec[]; void ac()
{
queue<int> q;
for(int i = ; i <= n; i++)
{
if(du[i] == )
q.push(i);
}
while(!q.empty())
{
int tmp = q.front(); q.pop();
sum = (sum + virus[tmp]) % mod; //把所有前驱点为 tmp 的点的病毒数都加上 tmp的病毒数
for(int i = ; i < vec[tmp].size(); i++)
{
int b = vec[tmp][i];
virus[b] = (virus[tmp] + virus[b]) % mod;// 此处也一定要取模,
du[b]--;
if(du[b] == )
q.push(b);
}
vec[tmp].clear();
}
}
int main()
{
while(scanf("%d%d%d", &n, &m, &k) != EOF)
{
memset(virus, , sizeof(virus));
memset(du, , sizeof(du));
for(int i = ; i <= n; i++) vec[i].clear(); for(int i = ; i <= k; i++)
{
int x;
scanf("%d", &x);
virus[x]++;
}
for(int i = ; i <= m; i++)
{
int x, y;
scanf("%d%d", &x, &y);
vec[x].push_back(y);
du[y]++;
} sum = ;
ac();
printf("%d\n", sum);
}
return ;
}
hiho拓扑排序专题 ——第四十八、四十七周的更多相关文章
- Unity 游戏框架搭建 2019 (四十八/四十九) MonoBehaviourSimplify 中的消息策略完善&关于发送事件的简单封装
MonoBehaviourSimplify 中的消息策略完善 在上一篇,笔者说,MonoBehaviourSimplify 中的消息策略还有一些小问题.我们在这篇试着解决一下. 先贴出来代码: usi ...
- NeHe OpenGL教程 第四十八课:轨迹球
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
- SQL注入之Sqli-labs系列第四十七关,第四十八关,第四十九关(ORDER BY注入)
0x1 源码区别点 将id变为字符型:$sql = "SELECT * FROM users ORDER BY '$id'"; 0x2实例测试 (1)and rand相结合的方式 ...
- 《手把手教你》系列技巧篇(四十八)-java+ selenium自动化测试-判断元素是否可操作(详解教程)
1.简介 webdriver有三种判断元素状态的方法,分别是isEnabled,isSelected 和 isDisplayed,其中isSelected在前面的内容中已经简单的介绍了,isSelec ...
- 第四十八个知识点:TPM的目的和使用方法
第四十八个知识点:TPM的目的和使用方法 在检查TPM目的之前,值得去尝试理解TPM设计出来的目的是为了克服什么样的问题.真正的问题是信任.信任什么?首先内存和软件运行在电脑上.这些东西能直接的通过操 ...
- hiho一下 第四十八周 拓扑排序·二【拓扑排序的应用 + 静态数组 + 拓扑排序算法的时间优化】
题目1 : 拓扑排序·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho所在学校的校园网被黑客入侵并投放了病毒.这事在校内BBS上立刻引起了大家的讨论,当 ...
- [hihoCoder] 第四十八周: 拓扑排序·二
题目1 : 拓扑排序·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho所在学校的校园网被黑客入侵并投放了病毒.这事在校内BBS上立刻引起了大家的讨论,当 ...
- abp(net core)+easyui+efcore实现仓储管理系统——入库管理之十二(四十八)
abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...
- SQL注入之Sqli-labs系列第四十一关(基于堆叠注入的盲注)和四十二关四十三关四十四关四十五关
0x1普通测试方式 (1)输入and1=1和and1=2测试,返回错误,证明存在注入 (2)union select联合查询 (3)查询表名 (4)其他 payload: ,( ,( 0x2 堆叠注入 ...
随机推荐
- 剑指OFFER之二维数组中的查找(九度OJ1384)
题目描述: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项.斐波那契数列的定义如下: 输入: 输入可能包含多个测试样例,对于每个测试案例, 输入包括一个整数n(1< ...
- MEF 编程指南(一):在应用中托管 MEF
在应用程序中托管(Hosing) MEF 涉及到创建组合容器(CompositionContainer) 实例,添加可组合部件(Composable Parts),包括应用程序宿主(Host)本身并进 ...
- cocos2d-x 纹理源码分析
转自:http://blog.csdn.net/honghaier/article/details/8068895 当一张图片被加载到内存后,它是以纹理的形式存在的.纹理是什么东西呢?纹理就是一块内存 ...
- CentOS 6系统下安装 JDK1.6
CentOS 6系统下安装 JDK1.6 JDK(Java Development Kit)是Sun Microsystems针对Java开发员的产品.自从Java推出以来,JDK已经成为使用最广泛的 ...
- Spring 3 整合Apache CXF WebService[转]
http://www.cnblogs.com/hoojo/archive/2012/07/13/2590593.html 在CXF2版本中,整合Spring3发布CXF WebService就更加简单 ...
- MySQL常用查询语句集合《转》
一查询数值型数据: SELECT * FROM tb_name WHERE sum > 100; 查询谓词:>,=,<,<>,!=,!>,!<,=>,= ...
- android Camera 数据流程分析
这篇文章主要针对其数据流程进行分析.Camera一般用于图像浏览.拍照和视频录制.这里先对图像浏览和拍照的数据流进行分析,后面再对视频电话部分进行分析. 1.针对HAL层对摄像头数据处理补充一下 Li ...
- hdu 4099 Revenge of Fibonacci 字典树+大数
将斐波那契的前100000个,每个的前40位都插入到字典树里(其他位数删掉),然后直接查询字典树就行. 此题坑点在于 1.字典树的深度不能太大,事实上,超过40在hdu就会MLE…… 2.若大数加法时 ...
- android广播集合,intent,action
android.permission.ACCESS_CHECKIN_PROPERTIES 同意读写訪问"properties"表在checkin数据库中,改值能够改动上传( All ...
- iOS开发——UI篇&ScrollView详解
创建方式 1:StoryBoard/Xib 这里StoarBoard就不多说,直接拖就可以,说太多没意思,如果连这个都不会我只能先给你跪了! 2:代码: CGRect bounds = [ [ UIS ...