题解 p2017 [USACO09DEC]晕牛Dizzy Cows
前言:P大终于又更新了
正文
由于当时我这个ZZ不知怎么了,这份题解排版可能有些尴尬,建议大家读完题后,看我主程序前的代码的注释,然后看最下面的图片,然后看第一张图片,对不起,望多谅解
以样例为例。具体看代码及其中的注释,这样做的正确性,看最下面说明
#include<iostream>#include<cstdio>#include<queue>using namespace std;/* 晕牛:拓扑排序 根据题干可知,有向边不成环,所以通过拓扑排序可以知道哪个入度少 当你强行把拓扑排序后在排序位置前面的点a和排序在后面的点b链接这一起 形成一条从b到a的有向边,则就会形成环。 而未避免形成环,就要在后面读入无向图时进行判断 而此题由于无向图的双向性不好处理, 于是,就规定输入第一个数字为出度,第二个数字为入度 先把不会形成环的点跑一个拓扑排序 然后在判断让某些点强行连接后会不会有环 会就改方向,不会就不用管 */const int MAXN=100001;int tot,a,b,n,p1,p2,cnt;int top[MAXN];//top是拓扑排序后每个数的编号 int head[MAXN],ver[MAXN],nxt[MAXN],deg[MAXN];//存图 void add(int x,int y){ ver[++tot]=y;nxt[tot]=head[x]; head[x]=tot;deg[y]++;}void topsort(){//拓扑排序 queue<int> q; for(register int i=1;i<=n;i++) if(deg[i]==0) q.push(i),top[i]=++cnt; //先扫一遍,把初始就没有入度的排序 while(q.size()){ int x=q.front();q.pop(); for(register int i=head[x];i;i=nxt[i]){ int y=ver[i]; //y是该到某个边的出度点了 if(!(--deg[y])) q.push(y),top[y]=++cnt; //如果它入度为零的话,就把它塞进栈里 } }}int main(){ scanf("%d%d%d",&n,&p1,&p2); for(register int i=1;i<=p1;i++) scanf("%d%d",&a,&b),add(a,b); topsort(); for(register int i=1;i<=p2;i++){ scanf("%d%d",&a,&b); if(top[a]>top[b]) printf("%d %d\n",b,a); //如果在原本拓扑排序中a的序列在b后面,强行连一条从a到b的边,会有环 else printf("%d %d\n",a,b); } return 0;}
说明
国际惯例:thankyou for your attention
题解 p2017 [USACO09DEC]晕牛Dizzy Cows的更多相关文章
- 洛谷P2017 [USACO09DEC]晕牛Dizzy Cows [拓扑排序]
题目传送门 晕牛Dizzy Cows 题目背景 Hzwer 神犇最近又征服了一个国家,然后接下来却也遇见了一个难题. 题目描述 The cows have taken to racing each o ...
- [USACO09DEC]晕牛Dizzy Cows (拓扑排序)
https://www.luogu.org/problem/P2017 题目背景 Hzwer 神犇最近又征服了一个国家,然后接下来却也遇见了一个难题. 题目描述 The cows have taken ...
- [USACO09DEC] Dizzy Cows 拓扑序
[USACO09DEC] Dizzy Cows 拓扑序 先对有向边跑拓扑排序,记录下每个点拓扑序,为了使最后的图不存在环,加入的\(p2\)条无向边\(u,v\)必须满足\(u\)拓扑序小于\(v\) ...
- 【P3056】【USACO12NOV】笨牛Clumsy Cows
P3056 [USACO12NOV]笨牛Clumsy Cows 题目描述 Bessie the cow is trying to type a balanced string of parenthes ...
- 树形DP【洛谷P3047】 [USACO12FEB]附近的牛Nearby Cows
P3047 [USACO12FEB]附近的牛Nearby Cows 农民约翰已经注意到他的奶牛经常在附近的田野之间移动.考虑到这一点,他想在每一块土地上种上足够的草,不仅是为了最初在这片土地上的奶牛, ...
- 洛谷 P3047 [USACO12FEB]附近的牛Nearby Cows
P3047 [USACO12FEB]附近的牛Nearby Cows 题目描述 Farmer John has noticed that his cows often move between near ...
- 洛谷 P3056 [USACO12NOV]笨牛Clumsy Cows
P3056 [USACO12NOV]笨牛Clumsy Cows 题目描述 Bessie the cow is trying to type a balanced string of parenthes ...
- 【题解】Luogu p3047 [USACO12FEB]附近的牛Nearby Cows 树型dp
题目描述 Farmer John has noticed that his cows often move between nearby fields. Taking this into accoun ...
- 洛谷P2017晕牛
传送门啦 这个题没有想象中复杂. 我们先有向边建立,因为我们无法改变有向边的方向. 建立完之后跑一边拓扑排序,我们按拓扑序小的指向大的就好了. 解释: 我们知道如果一个点在另一个点顺序的后面的话,如果 ...
随机推荐
- vue生命周期小笔记
一张图谨记vue每个生命周期的获取状态 beforecreate :可以在这加个loading事件 created :在这结束loading,还做一些初始化,实现函数自执行 mounted : 在这发 ...
- 《官方资料》 例如:string 函数 、分组函数
site:www.mysql.com SUBSTRING_INDEX ----------------------------------------------------------------- ...
- 2016-2017 《移动平台开发》实验三 敏捷开发与XP实践
概述 软件=程序+软件工程 软件企业=软件+商业模式 XP是一种轻量(敏捷).高效.低风险.柔性.可预测.科学而且充满乐趣的软件开发方式. 在更短的周期内,更早地提供具体.持续的反馈信息. 在迭代的进 ...
- 装饰者模式及C++实现
装饰者模式 时常会遇到这样一种情况,我已经设计好了一个接口,并且也有几个实现类,但是这时我发现我设计的时候疏忽了,忘记了一些功能,或者后来需求变动要求加入一些功能,最简单的做法就是修改接口,添加函数, ...
- CAS实战の获取多用户信息
先列出版本号: 服务端版本:cas server 4.0.0 客户端版本:cas client 3.3.3 cas server step1:先将primaryPrincipalResolver be ...
- GlusterFS 一
GlusterFS 一 1 安装源 yum install centos-release-gluster312.noarch 列出所有可用安装包yum list gluster* 安装glusterf ...
- 【转发】在SQL Server中通过字段值查询存储该字段的表
-- Copyright © 2002 Narayana Vyas Kondreddi. All rights reserved. -- Purpose: To search all colu ...
- 基于pscp批量分发文件
用法: pscp -h 目标ip文件 本地文件路径 远程路径 pscp -h hosts.ip file.txt ~/
- C/C++,python,java,C#月经贴问题
在刚开始的时候,一直纠结于语言之争,什么什么有前途,什么什么没前途.对于什么的支持不好啦,个人信仰问题啦.什么都有. 首先最主要的一个个人观点:“语言不是老婆,不是一夫一妻制”.你可以同时拥有许多的女 ...
- shell、cmd、dos和脚本语言区别和联系
问题一:DOS与windows中cmd区别 在windows系统中,“开始-运行-cmd”可以打开“cmd.exe”,进行命令行操作. 操作系统可以分成核心(kernel)和Shell(外壳)两部 ...