题目传送门


题目描述

知名美食家小A被邀请至ATM大酒店,为其品评菜肴。

ATM酒店为小A准备了N道菜肴,酒店按照为菜肴预估的质量从高到低给予1到N的顺序编号,预估质量最高的菜肴编号为1。由于菜肴之间口味搭配的问题,某些菜肴必须在另一些菜肴之前制作,具体的,一共有M条形如“i号菜肴‘必须’先于j号菜肴制作”的限制,我们将这样的限制简写为<i,j>。

现在,酒店希望能求出一个最优的菜肴的制作顺序,使得小A能尽量先吃到质量高的菜肴:也就是说,
  (1)在满足所有限制的前提下,1号菜肴“尽量”优先制作;
  (2)在满足所有制,1号菜肴“尽量”优先制作的前提下,2号菜肴“尽量”优先制作;
  (3)在满足所有限制,1号和2号菜肴“尽量”优先的前提下,3号菜肴“尽量”优先制作;
  (4)在满足所有制,1号和2号和3号菜肴“尽量”优先的前提下,4号菜肴“尽量”优先制作;
  (5)以此类推。
例一:共4道菜肴,两条限制<3,1>、<4,1>,那么制作顺序是3,4,1,2。
例二:共5道菜肴,两条限制<5,2>、 <4,3>,那么制作顺序是1,5,2,4,3。
例一里,首先考虑1,因为有限制<3,1>和<4,1>,所以只有制作完3和4后才能制作1,而根据(3),3号又应“尽量”比4号优先,所以当前可确定前三道菜的制作顺序是3,4,1;接下来考虑2,确定最终的制作顺序是3,4,1,2。
例二里,首先制作1是不违背限制的;接下来考虑2时有<5,2>的限制,所以接下来先制作5再制作2;接下来考虑3时有<4,3>的限制,所以接下来先制作4再制作3,从而最终的顺序是1,5,2,4,3。
现在你需要求出这个最优的菜肴制作顺序。无解输出“Impossible!” (不含引号,首字母大写,其余字母小写)。

输入格式

第一行是一个正整数D,表示数据组数。

接下来是D组数据。 
对于每组数据: 
第一行两个用空格分开的正整数N和M,分别表示菜肴数目和制作顺序限
制的条目数。 
接下来M行,每行两个正整数x,y,表示“x号菜肴必须先于y号菜肴制作”
的限制。(注意:M条限制中可能存在完全相同的限制)

输出格式

输出文件仅包含D行,每行N个整数,表示最优的菜肴制作顺序,或者“Impossible!”表示无解(不含引号)。


样例

样例输入:
3
5 4
5 4
5 3
4 2
3 2
3 3
1 2
2 3
3 1
5 2
5 2
4 3
样例输出:
1 5 3 4 2
Impossible!
1 5 2 4 3
样例解释:
第二组数据同时要求菜肴1先于菜肴2制作,菜肴2先于菜肴3制作,菜肴3先于菜肴1制作,而这是无论如何也不可能满足的,从而导致无解。

数据范围与提示

100%的数据满足N,M≤100000,D≤3。

题解

首先,这种题应该都能想到拓扑排序,如果你没想到那我也没法,如果你说不知道什么是拓扑排序,那……
然后就会想,把拓扑排序里的队列换成小跟堆。
的确,会有15分。
那么为什么不对呢?
因为我们在决策当前先走哪个点的时候并不知道后面会发生什么,而这道题恰恰要求我们只尽可能的让权值小的先输出出来。
那完了……
怎么办?考虑这样一个思路,反向建图,用大跟堆,最后反向输出。
为什么这样就对了呢?因为这样是先走尽可能大的节点,实在不行了才走小的节点,这样就保证了结果的最优性。

代码时刻

#include<bits/stdc++.h>
using namespace std;
struct rec
{
int nxt;
int to;
}e[100001];
int n,m;
int head[100001],cnt;
int d[100001];
int ans[100001];
bool flag;
priority_queue<int,vector<int>,less<int> > q;//大跟堆
void add(int x,int y)//建边
{
e[++cnt].nxt=head[x];
e[cnt].to=y;
head[x]=cnt;
}
void topsort()//拓扑排序
{
for(int i=n;i;i--)
if(!d[i])q.push(i);
while(!q.empty())
{
int flag=q.top();
q.pop();
ans[++ans[0]]=flag;
for(int i=head[flag];i;i=e[i].nxt)
{
d[e[i].to]--;
if(!d[e[i].to])q.push(e[i].to);
}
}
if(ans[0]<n)puts("Impossible!");//如果存在环
else
{
for(int i=ans[0];i;i--)//输出答案
printf("%d ",ans[i]);
puts("");
}
}
void pre_work()//多测不清空,爆零两行泪TAT……
{
memset(d,0,sizeof(d));
memset(head,0,sizeof(head));
cnt=flag=ans[0]=0;
}
int main()
{
int D;
scanf("%d",&D);
while(D--)
{
pre_work();
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
int x,y;
scanf("%d%d",&x,&y);
d[x]++;
add(y,x);//反向建边
}
topsort();
}
return 0;
}

rp++

[BZOJ4010]:[HNOI2015]菜肴制作(拓扑排序)的更多相关文章

  1. BZOJ4010[HNOI2015]菜肴制作——拓扑排序+堆

    题目描述 知名美食家小 A被邀请至ATM 大酒店,为其品评菜肴. ATM 酒店为小 A 准备了 N 道菜肴,酒店按照为菜肴预估的质量从高到低给予 1到N的顺序编号,预估质量最高的菜肴编号为1.由于菜肴 ...

  2. BZOJ4010: [HNOI2015]菜肴制作(拓扑排序 贪心)

    题意 题目链接 Sol 震惊,HNOI竟出NOI原题 直接在反图上贪心一下. // luogu-judger-enable-o2 // luogu-judger-enable-o2 #include& ...

  3. 【BZOJ4010】[HNOI2015]菜肴制作 拓扑排序

    [BZOJ4010][HNOI2015]菜肴制作 Description 知名美食家小 A被邀请至ATM 大酒店,为其品评菜肴. ATM 酒店为小 A 准备了 N 道菜肴,酒店按照为菜肴预估的质量从高 ...

  4. bzoj 4010: [HNOI2015]菜肴制作 拓扑排序

    题目链接: 题目 4010: [HNOI2015]菜肴制作 Time Limit: 5 Sec Memory Limit: 512 MB 问题描述 知名美食家小 A被邀请至ATM 大酒店,为其品评菜肴 ...

  5. 【bzoj4010】[HNOI2015]菜肴制作 拓扑排序+堆

    题目描述 给你一张有向图,问:编号-位置序(即每个编号的位置对应的序列)最小(例如1优先出现在前面,1位置相同的2优先出现在前面,以此类推)的拓扑序是什么? 输入 第一行是一个正整数D,表示数据组数. ...

  6. [LOJ2114][HNOI2015]-菜肴制作-拓扑排序+贪心

    <题面> 一个蒟蒻的痛苦一天 在今天的节目集训中,麦蒙将带领大家学习9种错误的解题策略 $15\%$算法(看两个就往下走吧) 1> puts("Impossible!&qu ...

  7. 洛谷P3243 [HNOI2015]菜肴制作 拓扑排序+贪心

    正解:拓扑排序 解题报告: 传送门! 首先看到它这个约束就应该要想到拓扑排序辣QwQ 首先想到的应该是用优先队列代替队列,按照节点编号排序 然后也很容易被hack:<5,1> 正解应为5, ...

  8. 洛谷P3243 [HNOI2015]菜肴制作——拓扑排序

    题目:https://www.luogu.org/problemnew/show/P3243 正向按字典序拓扑排序很容易发现是不对的,因为并不是序号小的一定先做: 但若让序号大的尽可能放在后面,则不会 ...

  9. 【luoguP3243】[HNOI2015]菜肴制作--拓扑排序

    题目描述 知名美食家小 A被邀请至ATM 大酒店,为其品评菜肴. ATM 酒店为小 A 准备了 N 道菜肴,酒店按照为菜肴预估的质量从高到低给予1到N的顺序编号,预估质量最高的菜肴编号为1. 由于菜肴 ...

  10. [bzoj4010][HNOI2015]菜肴制作_贪心_拓扑排序

    菜肴制作 bzoj-4010 HNOI-2015 题目大意:给定一张n个点m条边的有向图,求一个toposort,使得:(1)满足编号为1的点尽量在前:(2)满足(1)的情况下编号为2的点尽量在前,以 ...

随机推荐

  1. HDU-5201 The Monkey King

    题目描述 \(m\)个猴子分\(n\)个桃,要求第一个猴子的桃数严格大于其他猴子,问有多少种分法对\(1e9+7取模(\%1e9+7)\) Input \(1≤T≤25 ,1≤n,m≤100000\) ...

  2. Python进阶编程 反射

    1.7反射 python面向对象中的反射:通过字符串的形式操作对象相关的属性.python中的一切事物都是对象(都可以使用反射) class Foo: f = '类的静态变量' def __init_ ...

  3. Mac 基于Anaconda的TensorFlow安装笔记

    最近在中国大学MOOC平台学习北大的曹健老师上的“人工智能实践——Tensorflow”课程,开始我的人工智能之旅.第一天,讲解如何搭建实验室环境,我是mac系统,所以只写mac系统上的实验室环境安装 ...

  4. 【测试环境】TCPCopy 使用方法

    https://blog.csdn.net/ronmy/article/details/65657691 TCPCopy是一种请求复制(所有基于tcp的packets)工具,可以把在线请求导入到测试系 ...

  5. django admin站点美化

    使用django-simpleui 安装 pip install  django-simpleui 源码地址 https://github.com/newpanjing/simpleui django ...

  6. FP Style 的快排

    const quickSort = (list) => { if (!list || !list.length) return []; if (list.length === 1) return ...

  7. AutoLayout and Sizeclasses讲解

    iOS8和iPhone6发布已经过去蛮久了,广大的果粉终于迎来了大屏iPhone,再也不用纠结为大屏买三星舍苹果了…但是对于iOS开发人员来说,迎来了和Android开发开发一样的问题—>各种屏 ...

  8. Scala Option 从官方DOC解析

    Represents optional values. Instances of Option are either an instance of scala.Some or the object N ...

  9. Windows 下apache https配置(phpstudy)

    1.首先获取证书,https://www.pianyissl.com/  免费三个月的 或者 自己生成私钥.证书,然后应用到apache中. http://blog.sina.com.cn/s/blo ...

  10. PAT Basic 1042 字符统计 (20 分)

    请编写程序,找出一段给定文字中出现最频繁的那个英文字母. 输入格式: 输入在一行中给出一个长度不超过 1000 的字符串.字符串由 ASCII 码表中任意可见字符及空格组成,至少包含 1 个英文字母, ...