逆拓扑排序 HDU2647Reward
这个题如果用邻接矩阵的话,由于n比较大,会超内存,所以选用邻接表的形式。还有就是这个题有那个等级的问题,一级比一级的福利高,所以不能直接拓扑排序,而是反过来,计算出度,找出度为0的顶点,然后更新出度数组,等级更新的时候要判断是否比原来的等级大,具体看代码
/*************************************************************************
> File Name: hdu_1647.cpp
> Author:
> Mail:
> Created Time: 2015年03月28日 星期六 16时18分47秒
************************************************************************/ #include<iostream>
#include <cstdio>
#include <cstring>
#include <stdlib.h>
using namespace std;
const int N = ;
int OutDegree[N];//出度
struct Node{//邻接表
int start;
struct Node *next;
};
Node *node[N];
int n, m, ans;
int level[N];//等级
bool Topo()
{
int cnt = ;//统计个数
for (int i = ; i <= n; i++)
{
for (int j = ; j <= n; j++)
{
if (OutDegree[j] == )//找到出度为0的顶点
{
cnt++;
OutDegree[j]--;
ans += level[j] + ;
Node *tmp = node[j]->next;
while (tmp != NULL)//将所有跟他有关的边去掉
{
OutDegree[tmp->start]--;
level[tmp->start] = max(level[tmp->start], level[j] + );//比较等级之间的关系,取较大的那个
tmp = tmp->next;
}
}
}
}
if (cnt == n)//判断是否存在环
return true;
return false;
}
int main()
{
while (~scanf("%d %d", &n, &m))
{
ans = ;
int a, b;
memset(level, , sizeof(level));
memset(OutDegree, , sizeof(OutDegree));
for (int i = ; i <= n; i++)//初始化
{
node[i] = (Node *)malloc(sizeof(Node));
node[i]->start = ;
node[i]->next = NULL;
} for (int i = ; i < m; i++)
{
scanf("%d %d", &a, &b);
OutDegree[a]++;
Node *tmp = node[b];
while (tmp->next != NULL)
tmp = tmp->next;
Node *new_node = (Node *)malloc(sizeof(Node));
new_node->start = a;
new_node->next = NULL;
tmp->next = new_node;
}
if (Topo())
printf("%d\n", ans);
else
puts("-1");
for (int i = ; i <= n; i++)
free(node[i]);
} return ;
}
逆拓扑排序 HDU2647Reward的更多相关文章
- Leetcode207--->课程表(逆拓扑排序)
题目: 课程表,有n个课程,[0, n-1]:在修一个课程前,有可能要修前导课程: 举例: 2, [[1,0]] 修课程1前需要先修课程0 There are a total of 2 courses ...
- HDOJ 2647 Reward 【逆拓扑排序+分层】
题意:每一个人的基础工资是888. 因为一部分人要显示自己水平比較高,要求发的工资要比其它人中的一个人多.问你能不能满足他们的要求,假设能的话终于一共要发多少钱,假设不能就输出-1. 策略:拓扑排序. ...
- 逆拓扑排序 Reward HDU - 2647
Reward HDU - 2647 题意:每个人的起始金额是888,有些人觉得自己做的比另一个人好所以应该多得一些钱,问最少需要花多少钱,如果不能满足所有员工的要求,输出 -1 样例1: 2 1 1 ...
- 拓扑排序 --- hdu 4948 : Kingdom
Kingdom Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- hdu2647 逆拓扑,链式前向星。
pid=2647">原文地址 题目分析 题意 老板发工资,可是要保证发的工资数满足每一个人的期望,比方A期望工资大于B,仅仅需比B多1元钱就可以.老板发的最低工资为888元.输出老板最 ...
- POJ3687.Labeling Balls 拓扑排序
Labeling Balls Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 13201 Accepted: 3811 Descr ...
- PKU 3687 Labeling Balls(拓扑排序)
题目大意:原题链接 给出N个未编号的质量各不相同的球,以及它们质量轻重的大小关系,给它们从1-N贴标签编号,无重复.问是否存在可行的编号方法,不存在输出-1, 如果存在则输出唯一一种方案,此方案是使得 ...
- HDU2647-Reward(拓扑排序)
Reward Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- POJ3687 Labeling Balls(拓扑排序\贪心+Floyd)
题目是要给n个重量1到n的球编号,有一些约束条件:编号A的球重量要小于编号B的重量,最后就是要输出字典序最小的从1到n各个编号的球的重量. 正向拓扑排序,取最小编号给最小编号是不行的,不举出个例子真的 ...
随机推荐
- PAT-1041 Be Unique
Being unique is so important to people on Mars that even their lottery is designed in a unique way. ...
- 重拾C++ 基础知识总结(一)
1.使用gcc编译c++文件报错 proc1.cc:(.text+0x14): undefined reference to `std::cout' C++程序使用gcc命令只能编译,不能链接库文件 ...
- wariging for you oh~
- TCP/IP-入门
Life is not a rehearsal "人生没有彩排" 参考资料:TCP/IP入门经典 (第五版) TCP/IP详解 卷一:协议 一.什么是TCP/IP TCP/IP是一 ...
- 正则表达式 U贪婪模式
<?php/*模式修正符号: i u 位置:"//模式修正符位置" 可以一次使用一个,也可以一次使用多个 对整个正则表达式调优用的,也可以说是对正则表达式功能的扩展 &quo ...
- thinkphp 文件下载实例 实现以及注意事项
#下载 function download() { $id=$_GET['id']; $file_name ...
- 安卓环境搭建(1)hellow world
本系列适合0基础的人员,因为我就是从0开始的,此系列记录我步入Android开发的一些经验分享,望与君共勉!作为Android队伍中的一个新人的我,如果有什么不对的地方,还望不吝赐教. 在开始Andr ...
- 人见人爱a*b 杭电2035
求A^B的最后三位数表示的整数.说明:A^B的含义是“A的B次方” Input 输入数据包含多个测试实例,每个实例占一行,由两个正整数A和B组成(1<=A,B<=10000),如果A= ...
- java中dynamic web project与web project 的区别 [转]
原帖地址:http://blog.sina.com.cn/s/blog_46726d2401013jlk.html 文章框架: 1.Dynamic Web Project 概念 2.eclipse ...
- sql server 2005中使用with实现递归
WITH fw_requestion_note_temp(old_apply_id) AS ( --取根节点放入临时表 SELECT old_apply_id FROM fw_requestion_n ...