Reward

发工资,以前看过这题,做没做忘了(应该是没做)。

很明显的拓排。但数据范围这么大,吓得我当时就不敢动手。后来找题解发现还是相当于两层循环(are you kidding me?)当时卡在了不造怎么分层累加,比如4个人,2个关系,1>2,3>4。那么1,3在同一层,2,4在同一层。

题意:年终奖金最低888,但员工间有要求,n个员工,m个要求,m行每行两个数代表前一个人的工资要多于后一个人的。为了满足所有员工的要求,问boss最少需要多少money。

思路:二维数组爆内存,看到几个MLE的让我笑会。用vector存图,把前一个存进后一个里,前一个的度加一。q[v].push_back(u),好吧,比赛的时候,没想到要这样的。然后把所有度为0的放进队列里面。其实这就在计算第一层了。把与这些点相连的点的度全部减一,再把度变为0的点又加进队列里(第二层的)。重复操作。。判环可以把整个过程度为0的数量计算出来,再与n比较,也可以在最终队列结束后一层循环判断是否有度大于0的点,因为正常情况下所有的点都会进入队列一次,有环的话则度不会减为0也不会进入队列。

const int N=1e4+10;
vector<int>q[N];
queue<int>que;
int n,m,du[N],now;
void init()
{
now=888;//第0层的工资即初始工资;
for(int i=0; i<=n; i++) q[i].clear();
memset(du,0,sizeof(du));
while(!que.empty()) que.pop();
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
init();
int u,v;
while(m--)
{
scanf("%d%d",&u,&v);
q[v].push_back(u);//逆拓排;
du[u]++;
}
int cnt=0;
for(int i=1; i<=n; i++)
if(!du[i])
{
que.push(i);
cnt++;
}
int ans=0;
while(!que.empty())
{
int size=que.size();
while(size--)//按层累加
{
int v=que.front();
que.pop();
ans+=now;
for(int i=0; i<q[v].size(); i++)
{
int u=q[v][i];
du[u]--;
if(!du[u])
{
que.push(u);
cnt++;
}
}
}
now++;
}
int f=0;
for(int i=1;i<=n&&!f;i++)
if(du[i]) f=1;
if(f) printf("-1\n");
else printf("%d\n",ans);
}
return 0;
}

这样没超时我是比较奇怪的,拓排运用的并不是很多,也不是很熟练,这样也算加深对知识点的理解运用吧。

HDU-2647 Reward ,逆拓排。的更多相关文章

  1. ACM: hdu 2647 Reward -拓扑排序

    hdu 2647 Reward Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Des ...

  2. HDU.2647 Reward(拓扑排序 TopSort)

    HDU.2647 Reward(拓扑排序 TopSort) 题意分析 裸的拓扑排序 详解请移步 算法学习 拓扑排序(TopSort) 这道题有一点变化是要求计算最后的金钱数.最少金钱值是888,最少的 ...

  3. 题解报告:hdu 2647 Reward(拓扑排序)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2647 Problem Description Dandelion's uncle is a boss ...

  4. hdu 2647 Reward

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2647 Reward Description Dandelion's uncle is a boss o ...

  5. HDU 2647 Reward (拓扑排序)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2647 题意是给你n点m条有向边,叶子点(出度为0)上的值为888,父亲点为888+1,依次计算... ...

  6. HDU 2647 Reward(拓扑排序+判断环+分层)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2647 题目大意:要给n个人发工资,告诉你m个关系,给出m行每行a b,表示b的工资小于a的工资,最低工 ...

  7. HDU 2647 Reward(图论-拓扑排序)

    Reward Problem Description Dandelion's uncle is a boss of a factory. As the spring festival is comin ...

  8. hdu 2647 Reward(拓扑排序,反着来)

    Reward Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submis ...

  9. HDU 2647 Reward 【拓扑排序反向建图+队列】

    题目 Reward Dandelion's uncle is a boss of a factory. As the spring festival is coming , he wants to d ...

随机推荐

  1. [已读]JavaScript面向对象编程指南

    又是一个忽悠人的书名,其实这本书的花了大量内容阐述JS的基础语法,BOM,DOM,事件,ajax(这个和很多js书一样).最后一章则是编程模式与设计模式. 我觉得与面向对象没多大关系,要算的话,pro ...

  2. HDU 4366 Successor 分块做法

    http://acm.hdu.edu.cn/showproblem.php?pid=4366 今日重新做了这题的分块,果然是隔太久了,都忘记了.. 首先,用DFS序变成一维的问题 关键是它有两个权值, ...

  3. python_9(模块补充)

    第1章 re模块补充 1.1 贪婪匹配:回溯算法 1.2 .*?的用法 1.3 例:分组<name>取值 1.4 匹配整数删除小数 1.5 正则测试地址 第2章 重点模块 2.1 hash ...

  4. hadoop-0.20.2伪分布式安装简记

    1.准备环境 虚拟机(redhat enterprise linux 6.5) jdk-8u92-linux-x64.tar.gz hadoop-0.20.2.tar.gz 2.关闭虚拟机的防火墙,s ...

  5. MySQL优化步骤和my.cnf优化配置

    1.查看机器配置,指三大件:cpu.内存.硬盘 2.查看mysql配置参数 3.查看mysql运行状态,可以用mysqlreport工具来查看 4.查看mysql的慢查询 依次解决了以上问题之后,再来 ...

  6. H5图片预览功能

    <html> <head> <meta http-equiv="Content-Type" content="text/html; char ...

  7. AJPFX实现兔子问题

    有一对小兔子,从第三个月长成开始每个月生一对小兔子,新出生的小兔子从第三个月长成开始每个月也生一对小兔子,假设所有的兔子都不会死,问每个月兔子的总数?(月数可以是6,12).大神看看我笨方法谢的对吗? ...

  8. 列表、margin和padding的探讨、标签的分类

    一.列表 列表分为无序列表.有序列表和自定义列表 1.无序列表   <ul></ul> 1).内部必须有子标签,<li></li> 2).ul天生自带内 ...

  9. layer设置弹出全屏

    //弹出即全屏 var index = layer.open({ type: , content: 'http://www.layui.com', area: ['300px', '195px'], ...

  10. General mistakes in parallel computing

    这是2013年写的一篇旧文,放在gegahost.net上面  http://raison.gegahost.net/?p=97 March 11, 2013 General mistakes in ...