拓扑排序--P2881 [USACO07MAR]排名的牛Ranking the Cows
FJ想按照奶牛产奶的能力给她们排序。现在已知有$N$头奶牛$(1 ≤ N ≤ 1,000)$。FJ通过比较,已经知道了$M(1 ≤ M ≤ 10,000)$对相对关系。每一对关系表示为“X Y”,意指X的产奶能力强于Y。现在FJ想要知道,他至少还要调查多少对关系才能完成整个排序。
这道题和Floyd--P2419 [USACO08JAN]牛大赛Cow Contest有异曲同工之妙啊,但是2419我用的是$floyd$,对于$n^3$的做法,本题的数据范围n<=1000显然只能得到部分分(并不会bitset优化):
先说说$floyd$的60分作法:考虑我们如何能确定一头牛的排名?即本牛和其他所有牛的关系都确定。
1:预处理:输入$a$和$b$,$s[a][b]=1$表示$a$赢了$b$
2:$floyd$:如果$i$赢了$t$,$t$赢了$j$,$i$就赢了$j$($t$可以看做一个中转接点)
3:统计答案:如果俩头牛有一头赢了,那么另一头就输了,俩头牛的关系确定,而他不会自我矛盾,所以如果判断到两头牛没有一头赢,那么两头牛的关系不确定,答案+1,然后标记两头牛的关系确定(否则答案会重复)
代码:
#include <cstdio>
#include <algorithm>
#include <cmath>
#include <iostream>
#include <cstring>
using namespace std;
int n,m,a,b;
int s[][];
void Floyd(){
for (int t = ;t <= n;t++){
for (int i = ;i <= n;i++){
for (int j = ;j <= n;j++){
if (s[i][t]&&s[t][j])
s[i][j]=;
}
}
}
}
int main(){
int ans=;
scanf ("%d%d",&n,&m)
for (int i = ;i <= m;i++) {
scanf ("%d%d",&a,&b);
s[a][b]=;
}
Floyd();
for(int i = ;i <= n;i++){
for (int j = ;j <= n;j++){
if (i==j)continue;
if (s[i][j]==&&s[j][i]==){
ans++;
s[i][j]=;
}
}
}
cout<<ans;
return ;
}
拓扑作法:
1.预处理:构建一个图,从一头牛(节点)可以走到被他打败的牛(节点) $f[a][b]=1$,$a$打败了$b$,$degree[b]$++(被打败的牛(节点)的入度+1)
2.$bfs$(拓扑):从一个入度为0的节点出发(没有被打败过),由于我们构建的一个图,他的性质为当前节点打败了他的子节点,那么当前节点也打败了他子节点的子节点 $if(f[i][x])f[i][edge[k].to]=1$ 把子节点的入度减一
3.统计答案:如果俩头牛有一头赢了,那么另一头就输了,俩头牛的关系确定,而他不会自我矛盾,所以如果判断到两头牛没有一头赢,那么两头牛的关系不确定,答案+1,然后标记两头牛的关系确定(否则答案会重复)
代码:
#include<bits/stdc++.h>
using namespace std;
const int N=1e3+;
struct node{int to,next;}edge[N*];
int head[N],tot,degree[N];
bool f[N][N],vis[N],in[N];
int n,m,x,y,z,ans;
void add(int x,int y){
edge[++tot].to=y;
edge[tot].next=head[x];
head[x]=tot;
}
void bfs(){
queue<int>Q;
for(int i=;i<=n;i++)if(!degree[i])Q.push(i);
while(!Q.empty()){
int x=Q.front();Q.pop();vis[x]=;
for(int k=head[x];k;k=edge[k].next){
if(vis[edge[k].to])continue;
for(int i=;i<=n;i++)if(f[i][x])f[i][edge[k].to]=;
degree[edge[k].to]--;
if(degree[edge[k].to]==)Q.push(edge[k].to);
}
}
}
int main(){
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++)scanf("%d%d",&x,&y),add(x,y),f[x][y]=,degree[y]++;
bfs();
for(int i=;i<=n;i++){
for(int j=;j<=n;j++)if(!f[i][j]&&!f[j][i]&&i!=j)ans++,f[i][j]=;
}
printf("%d",ans);
}
拓扑排序--P2881 [USACO07MAR]排名的牛Ranking the Cows的更多相关文章
- 洛谷P2881 [USACO07MAR]排名的牛Ranking the Cows(bitset Floyd)
题意 题目链接 Sol 显然如果题目什么都不说的话需要\(\frac{n * (n - 1)}{2}\)个相对关系 然后求一下传递闭包减掉就行了 #include<bits/stdc++.h&g ...
- 洛谷 P2881 [USACO07MAR]排名的牛Ranking the Cows
题应该是假的...先不做了 https://www.cnblogs.com/Blue233333/p/7249057.html 比如输入5 0,答案是10,但可以比较8次就出来.就是在一个已知有序数列 ...
- 拓扑排序/DP【洛谷P2883】 [USACO07MAR]牛交通Cow Traffic
P2883 [USACO07MAR]牛交通Cow Traffic 随着牛的数量增加,农场的道路的拥挤现象十分严重,特别是在每天晚上的挤奶时间.为了解决这个问题,FJ决定研究这个问题,以能找到导致拥堵现 ...
- 洛谷P2017 [USACO09DEC]晕牛Dizzy Cows [拓扑排序]
题目传送门 晕牛Dizzy Cows 题目背景 Hzwer 神犇最近又征服了一个国家,然后接下来却也遇见了一个难题. 题目描述 The cows have taken to racing each o ...
- 牛客 51011 可达性统计(拓扑排序,bitset)
牛客 51011 可达性统计(拓扑排序,bitset) 题意: 给一个 n个点,m条边的有向无环图,分别统计每个点出发能够到达的点的数量(包括自身) \(n,m\le30000\). 样例: 10 1 ...
- sdut 2819 比赛排名(边表 拓扑排序)
题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2819 #include <iost ...
- 牛客寒假训练营3 B 处女座的比赛资格(拓扑排序+最短路)
题目链接 这个题,一眼看上去就是最短路的题,边权有负环显然不能用dij,然后出题人又卡了spfa,,那怎么办的想点办法啊,好像还有一个拓扑排序可以求最短路吧,这时候正解就已经得到了,就是拓扑排序求最短 ...
- 牛客多校第四场 J.Hash Function(线段树优化建图+拓扑排序)
题目传送门:https://www.nowcoder.com/acm/contest/142/J 题意:给一个hash table,求出字典序最小的插入序列,或者判断不合法. 分析: eg.对于序列{ ...
- 牛客网NOIP赛前集训营-提高组(第六场)-A-最长路[拓扑排序+hash+倍增]
题意 给定一个 \(n\) 点 \(m\) 边的边权非负的有向图,边有字符,求以每个点为开头的最长路字典序最小的路径 \(hash\) 值. \(n,m\leq 10^6\) 分析 首先建反图拓扑排序 ...
随机推荐
- 使用阿里云服务器配置frp实现Windows系统RDP内网穿透
1.frp服务器采用阿里云ecs的centos7.5系统,客户端是台windows10的系统,做一个RDP服务的内网穿透用. 2.首先下载frp到服务器(链接:https://github.com/f ...
- 碰到的问题——建设基于TensorFlow的深度学习环境
1.解决jupyter notebook问题:socket.error: [Errno 99] Cannot assign requested address 首先要生成一个jupyter的配置文件: ...
- ardrino#串口控制led
void setup() { pinMode(D6, OUTPUT); digitalWrite(D6,HIGH); Serial.begin(); } void loop() { String st ...
- 初识Python和使用Python爬虫
一.python基础知识了解: 1.特点: Python的语言特性: Python是一门具有强类型(即变量类型是强制要求的).动态性.隐式类型(不需要做变量声明).大小写敏感(var和VAR代表 ...
- JVM 学习笔记 - 带你掌握JVM类加载机制
前言 往期JVM系列: 精美图文带你掌握 JVM 内存布局 本节主要内容: 类的生命周期 类加载阶段描述 数组类和非数组类在加载阶段的差别 父子类初始化顺序 接口的初始化 JVM如何处理 多线程同时初 ...
- 对Python中列表和数组的赋值,浅拷贝和深拷贝的实例讲解
引用:https://www.jb51.net/article/142775.htm 列表赋值: 1 2 3 4 5 6 7 >>> a = [1, 2, 3] >>&g ...
- [Linux] day07——查看及过滤文本
查看及过滤文本 =====================================cat concatenate -n 添加行号------------------- ...
- python如何画三维图像?
python三维图像输出的代码如下所示:#画3D函数图像输出from mpl_toolkits.mplot3d import Axes3Dfrom matplotlib import cmimport ...
- 十八、oracle查看、扩展表空间及linux服务器硬盘容量大小查看
/*备注:表空间是数据库的逻辑组成部分从物理上将:数据库数据存放在数据文件中从逻辑上将:数据库则是存放在表空间中表空间由一个或是多个数据文件组成*/ --1.查看用户下面的所有的表SELECT * F ...
- php 实现店铺装修3
/** * @title 装修店铺 * @param plate_id 是 int 店铺装修样式ID * @param type 是 int 模板样式子板块类型(4-海景.6-二宫格.8-三宫格.9- ...