题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2535

   https://www.lydsy.com/JudgeOnline/problem.php?id=2109

考虑按拓扑序决策,发现不太行;主要是一种情况:虽然自己的 k[ ] 靠后,但自己限制的点的 k[ ] 靠前。

这样的话,自己应该尽量往前放;但为了别的点的这种情况,自己又应该尽量往后放,所以无法决策了。

发现这种情况主要和后面的点是否紧急有关。所以就是虽然拓扑序是那样的,但可以先决策的点应该是拓扑序靠后的点。

所以反着拓扑,然后按顺序决策。那么一个点就是在符合自己 k[ ] 的基础上尽量往后放就行了。

  这里能放的位置应该是自己 k[ ] 之前的第一个没被占用的位置,可以用并查集而不是 set (只是会变慢罢了)维护。

考虑第二问,则尽量先把其他点往后放,非放自己不可的时候再放自己,那么自己就被放在自己能放的最前面了。

  方法就是先决策其他点,遇到自己可以决策也不决策。最后非放自己不可的时候其他没放的点一定都是被自己限制的点,则自己只能放在当前空位的最后一个。

注意找自己的 k[ ] 之前的第一个没被占用的位置的时候应该考虑一下自己应该放在限制自己的那些点的前面!

  比如一个点限制要放在另一个点前面,但它的 k[ ] 却比那个点大;直接按刚才说的找位置的话自己可能放在限制自己点的后面了。

  要解决这种情况,只要拓扑的时候 k[ v ] 对 k[ cr ] 取 min 就行了。

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<set>
using namespace std;
const int N=,M=;
int n,m,hd[N],xnt,to[M],nxt[M],fa[N],sta[N],top;
int deg[N],ydeg[N],r[N],ans[N];
queue<int> q;
int rdn()
{
int ret=;bool fx=;char ch=getchar();
while(ch>''||ch<''){if(ch=='-')fx=;ch=getchar();}
while(ch>=''&&ch<='')ret=ret*+ch-'',ch=getchar();
return fx?ret:-ret;
}
int Mn(int a,int b){return a<b?a:b;}
void add(int x,int y){to[++xnt]=y;nxt[xnt]=hd[x];hd[x]=xnt;deg[y]++;}
int fnd(int a){return fa[a]==a?a:fa[a]=fnd(fa[a]);}
void solve(int cr)
{
memcpy(deg,ydeg,sizeof ydeg);
for(int i=;i<=n;i++)fa[i]=i;
top=;
for(int i=;i<=n;i++)if(!deg[i]&&i!=cr)sta[++top]=i;
while(top)
{
int k=sta[top--],d=fnd(r[k]);
fa[d]=fnd(d-);
for(int i=hd[k],v;i;i=nxt[i])
if(!(--deg[v=to[i]])&&v!=cr)sta[++top]=v;
}
printf("%d ",fnd(n));
}
int main()
{
n=rdn();m=rdn();
for(int i=;i<=n;i++)r[i]=rdn();
for(int i=,u,v;i<=m;i++)
{
u=rdn();v=rdn();add(v,u);
}
memcpy(ydeg,deg,sizeof deg);
for(int i=;i<=n;i++)fa[i]=i;
for(int i=;i<=n;i++)if(!deg[i])sta[++top]=i;
int deb=;
while(top)
{
int k=sta[top--],d=fnd(r[k]);
ans[d]=k;fa[d]=fnd(d-);
for(int i=hd[k],v;i;i=nxt[i])
{
r[v=to[i]]=Mn(r[v],r[k]);//
if(!(--deg[v]))sta[++top]=v;
}
}
for(int i=;i<=n;i++)printf("%d ",ans[i]);puts("");
for(int i=;i<=n;i++)solve(i);puts("");
return ;
}

bzoj 2535 && bzoj 2109 [Noi2010]Plane 航空管制——贪心的更多相关文章

  1. bzoj 2109: [Noi2010]Plane 航空管制

    Description 世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频 发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此, 小X表示很不满意. 在这次来烟台的 ...

  2. 【BZOJ2109/2535】【NOI2010】航空管制(贪心)

    [BZOJ2109/2535][NOI2010]航空管制(贪心) 题面 BZOJ2109 BZOJ2535 题解 很好玩的一道题目 先看第一问,显然是要找一个合法的拓扑排序的序列. 直接拓扑排序,把队 ...

  3. 2109&2535: [Noi2010]Plane 航空管制 - BZOJ

    Description世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此,小X表示很不满意. 在这次来烟台的路上, ...

  4. BZOJ 2535: [Noi2010]Plane 航空管制2

    Description 世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此,小X表示很不满意. 在这次来烟台的路上 ...

  5. BZOJ2109: [Noi2010]Plane 航空管制

    Description 世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频 发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此, 小X表示很不满意. 在这次来烟台的 ...

  6. BZOJ2535 [Noi2010]Plane 航空管制2

    Description 世博期间,上海的航空客运量大大超过了平时,随之而来的航空管制也频频发生.最近,小X就因为航空管制,连续两次在机场被延误超过了两小时.对此,小X表示很不满意. 在这次来烟台的路上 ...

  7. bzoj 2535: [Noi2010]Plane 航空管制2【拓扑排序+堆】

    有个容易混的概念就是第一问的答案不是k[i]字典序最小即可,是要求k[i]大的尽量靠后,因为这里前面选的时候是对后面有影响的(比如两条链a->b c->d,ka=4,kb=2,kc=3,k ...

  8. BZOJ2535: [Noi2010]Plane 航空管制2(拓扑排序 贪心)

    题意 题目链接 Sol 非常妙的一道题. 首先不难想到拓扑排序,但是直接对原图按\(k\)从小到大拓扑排序是错的.因为当前的\(k\)大并不意味着后面的点\(k\)也大 但是在反图上按\(k\)从大到 ...

  9. BZOJ2535 [Noi2010]Plane 航空管制 【贪心 + 堆】

    题目链接 BZOJ2535 题解 航班之间的关系形成了一个拓扑图 而且航班若要合法,应尽量早出发 所以我们逆拓扑序选点,能在后面出发的尽量后面出发,不会使其它点变得更劣,容易知是正确的 第二问只需枚举 ...

随机推荐

  1. ffmpeg播放RTSP的一点优化

    简单记录一下最近使用ffmpeg播放RTSP做的一点参数优化. 先做如下定义: AVDictionary* options = NULL; 1.画质优化 原生的ffmpeg参数在对1920x1080的 ...

  2. 图片服务器(FastDFS)的搭建

    1.1 什么是FastDFS FastDFS是用c语言编写的一款开源的分布式文件系统.FastDFS为互联网量身定制,充分考虑了冗余备份.负载均衡.线性扩容等机制,并注重高可用.高性能等指标,使用Fa ...

  3. Python内置函数详解-总结篇

    参考链接:http://www.cnblogs.com/sesshoumaru/p/6140987.html

  4. debug调试日志和数据查询

    手动删除es文件并释放磁盘空间 1.停掉服务 systemctl stop xsdaemon.service 2.删掉索引 rm -rf /home/storager/c3dceb5e-bacc-4a ...

  5. laravel中设置表单的方式,以及获取表单的提交的数据

  6. dell c6220II lsi阵列卡

    1.如果在lsi阵列卡上有多个raid,那么需要在第一个创建的raid上装系统,或者说先创建装系统的raid,否则可能报 hard disk error(centos 6.6) 2.热插拔的后果:如果 ...

  7. LeetCode OJ:Find Median from Data Stream(找数据流的中数)

    Median is the middle value in an ordered integer list. If the size of the list is even, there is no ...

  8. svn 图标状态说明

    http://blog.csdn.net/coslay/article/details/41980131

  9. 浅谈title属性与alt属性

    XHTML是CSS布局的基础,webjx.com一直强调XHTML知识的学习,重视语义和文档的结构.title 和alt 属性,给我最直观的感受就是,可以提高文档的适应性,并合理提高关键词密度.在XH ...

  10. Freemaker的java.beans.IntrospectionException: type mismatch between read and write methods

    引言:freemaker在特定的spring以及jdk下的问题解决路径. 环境描述 spring 3.1.1, jdk1.8u80, freemake 2.3.19 错误信息描述: 严重: Excep ...