Luogu P5603 小C与桌游【贪心+拓扑排序】
【Description】https://www.luogu.com.cn/problem/P5603
\(\;\)
题意可以简化为:一个不保证联通,n个点,m条边的DAG(有向无环图),构造一个拓扑序S。
求:\(\sum_{i=1}^n f(i)\)的\(Max,Min\)
其中\(f(i)\)的定义:
\begin{cases}
1\;\;\;\;S(1\;to\;i-1)<S(i) \\
0\;\;\;\;other
\end{cases}
\]
【Sample Input】
3 2
1 2
1 3
【Sample Output】
3
2
\(\;\)
\(\;\)
先考虑\(Max\)?
假设现在所有入度为0的点组成的集合为\(\{S_1,S_2,\cdots,S_k \;\;\;\}\;(S_1<S_2<\cdots <S_k)\)
可以贪心地考虑,目前选择\(S_1\)是最优的。
感性证明?
假设我们选择了\(S_r\),则\(S_1,\cdots,S_{r-1}\)在以后一定不会对答案产生贡献了。
而我们选择\(S_r\)唯一的好处就是:\(S_r\)可能是目前我们已选择中的最大值,会产生1的贡献
那我们完全可以先选择一个比\(S_r\)小的数\(S_p\),这样\(S_p\)也有可能产生贡献,而对\(S_r\)的是否贡献没有影响,会更优。
用一个优先队列(小根堆)实现即可。
\(\;\)
\(\;\)
考虑\(Min\)
接着上面的思路?
选择\(S_k\)是不是最优的?
举个反例:
在这个例子中,按照原先的思路是3-4-1-5,答案为3。
而选择3-1-5-4,答案为2。显然更优。
所以我们得到一个新的思路,只要有小于目前最大值的,就选,否则选最大的那一个。
感性证明?
因为小于目前最大值的点不管什么时候,都不会对答案产生贡献了,所以我们先把它们选了再说。
而这样的好处就是:可以扩展出更多的点,这样就更容易创造一个更优的方法。
例子中:选了1后,我们扩展到了5这个点,就可以使4不产生贡献。
否则如果我们不选1的话,只能选择4,这样可能导致不是最优解。
\(\;\)
\(Code:\)
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<queue>
#include<vector>
using namespace std;
const int N=500010;
int n,m,ind[N],bind[N];
vector<int> g[N];
priority_queue<int> q;
priority_queue<int,vector<int>,greater<int> > Q;
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
int u,v;
scanf("%d%d",&u,&v);
g[u].push_back(v);
ind[v]++;
}
for(int i=1;i<=n;i++)
{
bind[i]=ind[i];
if(!ind[i])
{
Q.push(i);
}
}
int maxn=0,res1=0,res2=0;
while(!Q.empty())
{
int u=Q.top(); Q.pop();
if(u>maxn)
{
res1++;
maxn=u;
}
for(int i=0;i<g[u].size();i++)
{
int v=g[u][i];
if(!(--ind[v]))
{
Q.push(v);
}
}
}
printf("%d\n",res1);
for(int i=1;i<=n;i++)
{
if(!bind[i])
{
q.push(i);
}
}
while(!q.empty())
{
while(!q.empty())
{
int u=q.top();
q.pop();
if(u>maxn)
{
res2++;
maxn=u;
}
tt.push(u);
}
while(!tt.empty())
{
int u=tt.front();
tt.pop();
for(int i=0;i<g[u].size();i++)
{
int v=g[u][i];
if(!(--bind[v]))
{
if(v<maxn)
{
tt.push(v);
}
else q.push(v);
}
}
}
}
printf("%d",res2);
return 0;
}
Luogu P5603 小C与桌游【贪心+拓扑排序】的更多相关文章
- [POI2004] SZP (贪心+拓扑排序)
[问题描述] Byteotian 中央情报局(BIA) 雇佣了许多特工. 他们每个人的工作就是监视 另一名特工. Byteasar 国王需要进行一次秘密行动,所以他要挑选尽量多的信得过的特工. 但 是 ...
- hdu-5695 Gym Class(贪心+拓扑排序)
题目链接: Gym Class Time Limit: 6000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- Aizu 2456 Usoperanto 贪心 拓扑排序
Usoperanto Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.bnuoj.com/v3/contest_show.php?cid= ...
- poj 3687 Labeling Balls - 贪心 - 拓扑排序
Windy has N balls of distinct weights from 1 unit to N units. Now he tries to label them with 1 to N ...
- 2016"百度之星" - 初赛(Astar Round2A)1006 Gym Class(HDU5695)——贪心+拓扑排序
分析:首先,利用贪心可知,如果要所有人的分数和最高,需要把序号大的优先放在前面.其次,对于a的前面不能为b,那么只能a在b前面了,那么就建立一条从a到b的边,并且b的入度加1.然后就是拓扑排序了.要分 ...
- Berland Army CodeForces - 883B (贪心,拓扑排序)
大意: n个点, 点$i$的等级为$r_i$, 只给出部分点的$r$值, $r_i$的范围为[1,k], 且[1,k]都至少有一个. 给定m条有向边, (x,y)表示$r[x]>r[y]$, 求 ...
- 「Luogu P5603」小O与桌游
题目链接 戳我 \(Solution\) 我们来分析题目. 实际上就是求一个拓扑序满足拓扑序的前缀最大值最多/最少 对于第一种情况,很明显一直选当前能选的最小的是最优的对吧.因为你需要大的尽可能多.用 ...
- Luogu P3065 [USACO12DEC]第一!First!【字典树/拓扑排序】By cellur925
题意:给你许多字符串,你可以改变字母序大小,问有哪些字符串可能成为字典序最小的字符串. 我们考虑把这些字符串都塞到\(trie\)树上.之后检索每一个字符串的时候,我们看和他同一层的地方是否有字符,如 ...
- 贪心+拓扑排序 AOJ 2456 Usoperanto
题目传送门 题意:给出一条链,比如x连到y,x一定要在y的左边,且代价是这条链经过的点的权值和,问如何排序使得代价最小 分析:类似拓扑排序,先把入度为0的点入队,把指向该点的所有点按照权值排序,保证这 ...
随机推荐
- .NET Core3.1总体预览和第一个Core程序的创建
小伙伴们大家好!欢迎阅读本贴,这里是常哥说编程的专栏,.NetCore已经出来一段时间了,很多小伙伴可能也开始了学习,但是.NetCore毕竟在学习上和我们常用的.NET Framework还是有很大 ...
- v&n赛 ML 第一步(python解决)
题目链接 给了70组x,y,根据提示,是求拟合曲线,再通过x求y 知道MATLAB应该录入就能解决吧,但是没下这软件,试试用python解决 #coding:utf- from pwn import ...
- 文字检测模型EAST应用详解 ckpt pb的tf加载,opencv加载
参考链接:https://github.com/argman/EAST (项目来源) https://github.com/opencv/opencv/issues/12491 (遇到的问题) ...
- Python模块---制作新冠疫情世界地图()
目录 pyecharts模块 简介 安装pyecharts 测试pyecharts模块 pyecharts实战:绘制新冠肺炎疫情地图 需求分析 请求数据 提取数据 处理数据 制作可视化地图 设置可视化 ...
- thinkphp5.1生成缩略图很模糊
缩略图一定要从大分辨率往小生成 $image->thumb(400,400,\think\Image::THUMB_CENTER)->save(Env::get('root_path'). ...
- python学习02python入门二
学前须知:1.本文档有关内容均建立在python3.x版本上,python2.x已经成为历史,如有需要,文内会特别说明. 2.本文使用的编辑器多为架构在Windows上的pycharm,如需了解Lin ...
- opencv-7-鼠标绘制自定义图形
opencv-7-鼠标绘制自定义图形 opencvc++qt 开始之前 昨天写了具体的基本的图形绘制, 然后我们使用相应的函数接口进行调用, 便能够在图像上绘制出来相应的图形, 我们以图像绘制为例, ...
- JDK 14的新特性:instanceof模式匹配
JDK 14的新特性:instanceof模式匹配 JDK14在2020年的3月正式发布了.可惜的是正式特性只包含了最新的Switch表达式,而Records,patterns,text blocks ...
- php数组存在重复的相反元素,去重复
$arr1=array('a_b','c_d','b_a','d_c'); $arr2=array('a_b','c_d','b_a','d_c'); 条件: a_b==b_a:c_d==d_c: 需 ...
- APP路由还能这样玩
本文主要讲述一种设计思路,组件化架构市面上已经有很多大厂成熟的方案,但是在组件化过程中,偶尔会遇到2个独立业务子模块间没有相互引用,也需要能直接调用对方的功能,因此我想到通过方法路由来解决,如果还有疑 ...