前言: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的更多相关文章

  1. 洛谷P2017 [USACO09DEC]晕牛Dizzy Cows [拓扑排序]

    题目传送门 晕牛Dizzy Cows 题目背景 Hzwer 神犇最近又征服了一个国家,然后接下来却也遇见了一个难题. 题目描述 The cows have taken to racing each o ...

  2. [USACO09DEC]晕牛Dizzy Cows (拓扑排序)

    https://www.luogu.org/problem/P2017 题目背景 Hzwer 神犇最近又征服了一个国家,然后接下来却也遇见了一个难题. 题目描述 The cows have taken ...

  3. [USACO09DEC] Dizzy Cows 拓扑序

    [USACO09DEC] Dizzy Cows 拓扑序 先对有向边跑拓扑排序,记录下每个点拓扑序,为了使最后的图不存在环,加入的\(p2\)条无向边\(u,v\)必须满足\(u\)拓扑序小于\(v\) ...

  4. 【P3056】【USACO12NOV】笨牛Clumsy Cows

    P3056 [USACO12NOV]笨牛Clumsy Cows 题目描述 Bessie the cow is trying to type a balanced string of parenthes ...

  5. 树形DP【洛谷P3047】 [USACO12FEB]附近的牛Nearby Cows

    P3047 [USACO12FEB]附近的牛Nearby Cows 农民约翰已经注意到他的奶牛经常在附近的田野之间移动.考虑到这一点,他想在每一块土地上种上足够的草,不仅是为了最初在这片土地上的奶牛, ...

  6. 洛谷 P3047 [USACO12FEB]附近的牛Nearby Cows

    P3047 [USACO12FEB]附近的牛Nearby Cows 题目描述 Farmer John has noticed that his cows often move between near ...

  7.  洛谷 P3056 [USACO12NOV]笨牛Clumsy Cows

    P3056 [USACO12NOV]笨牛Clumsy Cows 题目描述 Bessie the cow is trying to type a balanced string of parenthes ...

  8. 【题解】Luogu p3047 [USACO12FEB]附近的牛Nearby Cows 树型dp

    题目描述 Farmer John has noticed that his cows often move between nearby fields. Taking this into accoun ...

  9. 洛谷P2017晕牛

    传送门啦 这个题没有想象中复杂. 我们先有向边建立,因为我们无法改变有向边的方向. 建立完之后跑一边拓扑排序,我们按拓扑序小的指向大的就好了. 解释: 我们知道如果一个点在另一个点顺序的后面的话,如果 ...

随机推荐

  1. .net手动编写Windows服务

    1,打开VS,新建一个windows服务程序.项目名称自定义,我这里用的默认名称:Service1 2,打开Service1,按F7查看代码.代码里有三个方法:public Service1().pr ...

  2. 电商商品规则属性sku 工具类

    /** * 商品模块: * 使用:var SKU = sku.init({ id:'sku', item: item, data:data }); * @config item = [{"i ...

  3. [转]Android下怎么使用LDD查看依赖库

    Android下没有ldd可以使用,在进行ndk开发的时候,检查库的依赖项特别麻烦.有两个解决方案: 1.将linux的的ldd移植过去.因为android也是基于linux的,所以将ldd移植过去是 ...

  4. 自定义animate()引起的动画叠加

    当用户快速在某个元素多次执行动画时,会造成动画累积的现象.这时,就需要引入动画状态这个概念.判断元素是否处于动画状态中,如果处于,则不添加新动画 常常用于在设置动画之前未清除动画,造成的动画叠加.解决 ...

  5. 团体程序设计天梯赛L2-021 点赞狂魔 2017-04-18 11:39 154人阅读 评论(0) 收藏

    L2-021. 点赞狂魔 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 微博上有个"点赞"功能,你可以为你 ...

  6. handsontable-常用配置

    冻结单元格 var //自动创建数据 myData = Handsontable.helper.createSpreadsheetData(100, 50), container = document ...

  7. python signal

    在了解了Linux的信号基础之 后,Python标准库中的signal包就很容易学习和理解.signal包负责在Python程序内部处理信号,典型的操作包括预设信号处理函数,暂 停并等待信号,以及定时 ...

  8. 遇到了IE10不能登录的问题,很早就有解决方案了

    1..net 2.0 的程序,请打开项目,打开vs开发环境的工具菜单下的  Package Manager Console ,中文名:程序包管理控制台,在打开的控制台中输入如下命令:Install-P ...

  9. 比较git commit 两个版本之间次数

    #!/bin/bash f1="$1*" f2="$2*" echo "第一个版本:"$f1 echo "第二个版本:" ...

  10. DataTable转List<T>

    /// <summary> /// DataTable转List<T> /// </summary> public static class TableToList ...