2017-09-12 19:50:58

writer:pprp

最近刚开始接触拓扑排序,拓扑排序适用于:无圈图的顶点的一种排序,

用来解决有优先级别的排序问题,比如课程先修后修,排名等。

主要实现:用矩阵来储存图,用indegree数组记录每个顶点的入度,

从入度为0的开始,每次删除该入度为0的点,然后修改其他顶点的入度,

在进行查找入度为0的顶点,循环下去就可以

题意如下:给你n个队伍,m个优先顺序,让你输出总的排名的优先顺序。

代码如下:

/*
@theme:拓扑排序 hdu 1285
@writer:pprp
@declare: accepted
@begin:19:00
@end:19:47
@error:
*/ #include <iostream>
#include <cstring>
#include <cstdio> using namespace std;
const int maxn = ;
bool G[maxn][maxn];
int ans[maxn];
int indegree[maxn];//存取入度
int n, m; void init()
{
memset(indegree,,sizeof(indegree));
memset(ans,,sizeof(ans));
memset(G,,sizeof(G));
} void toposort()
{
for(int i = ; i <= n ; i++)
{
for(int j = ;j <= n ;j++)
{
if(G[i][j])
indegree[j]++;
}
}
//应该从入度为0的开始
for(int i = ; i <= n;i++)
{
int k = ;
while(indegree[k]!=)
k++;
ans[i] = k;
//删除根节点
indegree[k] = -;
for(int j = ; j <= n; j++)
{
if(G[k][j])
indegree[j]--;
}
} } int main()
{
//freopen("in.txt","r",stdin);
int x, y;
while(cin >> n >> m)
{
init();
for(int i = ; i < m ;i++)
{
cin >> x >> y;
G[x][y] = ;
} toposort(); for(int i = ; i < n; i++)
cout << ans[i] << " ";
cout << ans[n] << endl;
} return ;
}

分析当前的:

每次删掉一个点以后就要遍历全部的点找到入度为0的点,其实入度为0的点只可能出现在改动之后的点,

所以采用了优先队列,记录下来当前的入度为0的点,将其输出或者储存下来以后,改变由该点指向的点的入度

从这些改动的点中看看有没有入度为0的点,如果有的话,那就将其入队列,直到队列为空,或者记录的已经被删除的点的个数是所有的点

那么退出完成程序

优化代码如下:

/*
@theme:拓扑排序 hdu 1285
@writer:pprp
@declare: accepted
@begin:19:59
@end:20:38
@error:注意保持头脑清醒
*/ #include <iostream>
#include <cstring>
#include <algorithm>
#include <queue>
#include <cstdio> using namespace std;
const int maxn = ;
int indegree[maxn];
int n, m, x, y; bool G[maxn][maxn]; void topsort()
{
priority_queue<int,vector<int>,greater<int> > pq; for(int i = ; i <= n; i++)
for(int j = ; j <= n; j++)
if(G[i][j])
indegree[j]++; for(int i = ; i <= n; i++)
if(indegree[i] == )
pq.push(i),indegree[i] = -1; int counter = ; while(!pq.empty())
{
int v = pq.top();
pq.pop(); if(counter != n)
{
cout << v << " ";
counter++;
}
else
{
cout << v << endl;
break;
} for(int i = ; i <= n;i++)
{
if(G[v][i] == )
{
indegree[i]--;
if(indegree[i] == )
pq.push(i),indegree[i] = -1;
}
}
}
if(counter != n)
cerr << "graph has a cycle." << endl;
} void init()
{
memset(indegree,,sizeof(indegree));
memset(G,,sizeof(G));
} int main()
{
freopen("in.txt","r",stdin);
while(cin >> n >> m)
{
init();
for(int i = ; i < m ; i++)
{
cin >> x >> y;
G[x][y] = ;
}
topsort();
} return ;
}

拓扑排序 - hdu 1285(普通和优先队列优化)的更多相关文章

  1. 拓扑排序 HDU - 5695

    众所周知,度度熊喜欢各类体育活动. 今天,它终于当上了梦寐以求的体育课老师.第一次课上,它发现一个有趣的事情.在上课之前,所有同学要排成一列, 假设最开始每个人有一个唯一的ID,从1到NN,在排好队之 ...

  2. 拓扑排序 --- hdu 4948 : Kingdom

    Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Sub ...

  3. hdu1532 用BFS求拓扑排序

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1285 题目给出一些点对之间的先后顺序,要求给出一个字典序最小的拓扑排列.对于拓扑排序的问题,我们有DF ...

  4. bzoj4383 [POI2015]Pustynia 拓扑排序+差分约束+线段树优化建图

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4383 题解 暴力的做法显然是把所有的条件拆分以后暴力建一条有向边表示小于关系. 因为不存在零环 ...

  5. hdu 1285 确定比赛名次 拓扑排序

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1285 有N个比赛队(1<=N<=500),编号依次为1,2,3,....,N进行比赛,比赛 ...

  6. 图论之初,拓扑排序、前向星(通过存储边来存储图)加优先队列对拓扑的优化-----hdu1285

    确定比赛名次 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  7. ACM: HDU 1285 确定比赛名次 - 拓扑排序

     HDU 1285 确定比赛名次 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u De ...

  8. HDU 5638 拓扑排序+优先队列

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5638 题意: 给你一个DAG图,删除k条边,使得能个得到字典序尽可能小的拓扑排序 题解: 把拓扑排序 ...

  9. 正向与反向拓扑排序的区别(hdu 1285 确定比赛名次和hdu 4857 逃生)

    确定比赛名次 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submis ...

随机推荐

  1. zipline风险指标计算 (empyrical模块)

    概述 量化中,我们经常会遇到各种量化指标的计算,对于zipline来说,也会对这部分计算进行处理,由于指标计算的通用性比较强,所以,zipline单独封装了 empyrical 这个模块,可以处理类似 ...

  2. Python下的正则表达式原理和优化笔记

    摘要: 本文旨在总结一些编写表达式的技巧和原理.鉴于介绍python中re模块的使用方法的文章太多.所以本文在基础方面都是略过,而在回溯原理和一些技巧方面记录一点点学习总结. 目录:[ - ] 基础规 ...

  3. Redis在实际项目中的一应用场景

    1.在游戏的等级排名,可以将用户信息放入到redis的有序集合中,然后取得相应的排名,不用自己写代码去排序. 2.利用rediss的数据特性的自增,自减属性,可以将项目中的一些列入阅读数,点赞数放入到 ...

  4. (0.2.5)Mysql安装——RPM方式安装

    rpm安装mysql 卸载与安装服务端   一.安装服务端与客户端 #查看RPM包中所有的文件shell> rpm -qpl mysql-community-server-version-dis ...

  5. sql 区分大小写

    sql server默认是不区分大小写的. 要查看sqlserver数据库是否区分大小写,我么可以查看系统存储过程sys.sp_server_info exec sys.sp_server_info ...

  6. @JsonFormat与@DateTimeFormat注解的使用

    背景:从数据库获取时间传到前端进行展示的时候,我们有时候可能无法得到一个满意的时间格式的时间日期,在数据库中显示的是正确的时间格式,获取出来却变成了很丑的时间戳,@JsonFormat注解很好的解决了 ...

  7. .def文件如何编写

    DLL中导出函数的声明有两种方式:一种为在函数声明中加上__declspec(dllexport),这里不再举例说明:另外一种方式是采用模块定义(.def) 文件声明. 规则是:1.首先创建 一个DL ...

  8. JavaScript和jQuery的学习

    还有12天就要回学校了,我的假期计划还能实现吗?在这12天里,需要把JavaScript和jQuery学完.我知道这两个技术对于前端网页开发非常重要.前期把HTML和CSS学完了,学的不是特别深,只是 ...

  9. sublime2常用设置

    设置文本字体格式 • Preferences -> Setting-User • 加入设置:"font_face" : "courier new", &q ...

  10. PHP连接MYSQL操作数据库

    PHP连接MYSQL操作数据库 <?php $con = mysql_connect("localhost","root",""); ...