BZOJ3355
3355: [Usaco2004 Jan]有序奶牛
Time Limit: 10 Sec Memory Limit: 128 MB
Submit: 37 Solved: 19
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
3 5
4 2
5 2
2 1
3 1
4 1
Sample Output
2 1
3 5
4 2
5 2
HINT
3在1前,4在1前可推.输出的每一行,不能被其他推出.
分析:对于一条边x->y,若去掉之后x不能到达y,那么它是必需的。我们首先需要求出拓扑序列,然后我们按照拓扑序列反向加边,这样的目的就是为了在已知顺序的情况下维护哪些边可以互相到达,然后用一个bieset去判断一下哪些边是必须的。感谢claris和付大神对我的帮助
#include "iostream"
#include "cstdio"
#include "cstring"
#include "bitset"
#include "algorithm"
using namespace std;
const int maxn=+;
const int maxm=+;
int n,m,ed,ed2;
int ind[maxn]; //入度
int adj[maxm]; //栈顶边对应的顶点
int next1[maxm]; //上一条边的编号
int tail[maxm]; //栈顶边的编号
int vis[maxn]; //存储拓扑排序序列
bitset<maxn>f[maxn];
void add(int x,int y){
ind[y]++;
adj[++ed]=y;
next1[ed]=tail[x];
tail[x]=ed;
}
int adj2[maxm];
int next2[maxm];
int tail2[maxm];
void add2(int x,int y){
adj2[++ed2]=y;
next2[ed2]=tail2[x];
tail2[x]=ed2;
}
typedef pair<int,int> P;
P p[maxm];
int main()
{
//freopen("a.txt", "r", stdin);
//freopen("b.txt", "w", stdout);
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++) f[i][i]=;
ed=;
while(m--){ //数组式邻接表建图
int x,y;
scanf("%d%d",&x,&y);
add(x,y);
} //构造拓扑排序序列
int cnt=;
for(int i=;i<=n;i++)
if(!(ind[i]))
vis[++cnt]=i; int h=;
ed2=;
while(h<=cnt){
int a;
for(int i=tail[a=vis[h++]];i;add2(adj[i],a),i=next1[i])
if(!(--ind[adj[i]]))
vis[++cnt]=adj[i];
} int ans=;
for(int i=;i<=n;i++){
int a;
for(int j=tail2[a=vis[i]];j;f[a]|=f[adj2[j]],j=next2[j])
if(!f[a][adj2[j]])
p[++ans]=P(adj2[j],a);
}
sort(p+,p++ans);
printf("%d\n",ans);
for(int i=;i<=ans;i++)
printf("%d %d\n",p[i].first,p[i].second);
return ;
}
BZOJ3355的更多相关文章
- BZOJ3355 : [Usaco2004 Jan]有序奶牛
对于一条边x->y,若去掉之后x不能到达y,那么它是必需的. 首先拓扑排序求出拓扑序,然后按照终点拓扑序为第一关键字,起点拓扑序为第二关键字从小到大加边. 对于每个点,维护一个bitset,表示 ...
随机推荐
- AC日记——NASA的食物计划 洛谷 P1507
题目背景 NASA(美国航空航天局)因为航天飞机的隔热瓦等其他安 全技术问题一直大伤脑筋,因此在各方压力下终止了航天 飞机的历史,但是此类事情会不会在以后发生,谁也无法 保证,在遇到这类航天问题时,解 ...
- sugar与阿龙的互怼(第一季)
§ 第一季 回家风波 高考了,啦啦啦~ 快要高考了,显然sugar很伤心. 显然不是因为快要考试了sugar才伤心的. 那为什么??? 因为他们都回家了,但是sugar和他的小伙伴们都不回家!!! ...
- bzoj 5091: [Lydsy0711月赛]摘苹果
5091: [Lydsy0711月赛]摘苹果 Time Limit: 1 Sec Memory Limit: 256 MBSubmit: 148 Solved: 114[Submit][Statu ...
- springcloud 学习笔记
---恢复内容开始--- 1. pom配置 1.1 引入spring boot 依赖 <parent> <groupId>org.springframework.boot< ...
- Meteor 从一个列表页进入详情页怎样高速显示详情
无论是做android开发,还是做网页web开发,都 会有列表,都须要点击列表进入列表项的详情页面,查看具体信息,能常情况下,我们都是将这一列表项的id传到详情页,由详情页再到数据库查询具体信息. 在 ...
- 从实例看hibernate的主键生成策略
学习了hibernate会发现.hibernate中有实体类.实体类的映射文件.可是我们怎么样才干知道实体类的主键是如何的生成方式呢?hibernate提供的主键生成策略帮我们完美地解答了这个疑问.以 ...
- ios系统铃声调用方法
首先,这里我要说明这里并非真正调用系统内部自带的铃声,由于苹果是不同意开发人员调用的,没有给开发人员接口.假设调用了就无法上线的! 那为什么AppStore里面还有那么多app显示的效果是调用系统的铃 ...
- java开始到熟悉100-102
本次内容:arraylist() 1. package list; import java.util.ArrayList; import java.util.Date; import java.uti ...
- windows核心编程之进程间共享数据
有时候我们会遇到window进程间共享数据的需求,例如说我想知道系统当前有多少某个进程的实例. 我们能够在程序中定义一个全局变量.初始化为0.每当程序启动后就加1.当然我们我们能够借助第三方介质来储存 ...
- 手动编译一个c文件(Win7下如何使用GCC编译器)
主要参考这篇http://jingyan.baidu.com/article/c275f6bacc0126e33c756771.html 我没找到minGW的下载地址,而是直接用codeblocks自 ...