SGU326_Perspective
NBA打比赛。所有的比赛被分为多个团队。有的比赛是团内的,有的是与团外的队伍打的。
给出团内每个队伍已得分,以及总共有多少场比赛,还有团内所有队伍之间有多少场比赛?
问1队是否可能是分数最高的一个队伍。(题目没说是否唯一最高,枚举题意得知不是唯一)
又是一个竞赛图的最大流。团内的比赛,如果有一个队伍是1队,那么安排结果1队胜利,另一队伍失败。
对于所有与外团的比赛,与1队有关的都胜利,否则失败。
接下来建图,我们做完前面的工作后,分别统计所有的队伍得分,1队分数减去x队的分数就是x队在所有的团内赛中最多能够胜利的场数。
模型就出来了,源点->队伍->比赛->汇点,最终我们只要判断所有比赛的出边是否满流,即所有的比赛能否安排得下即可。
召唤代码君:
#include <iostream>
#include <cstdio>
#include <cstring>
#define maxn 5550
#define maxm 55550
using namespace std; int next[maxm],to[maxm],c[maxm],first[maxn],edge=-;
int score[maxn],test[maxn],tag[maxn],TAG=;
bool can[maxn];
int a[][],node=-,d[maxn];
int Q[maxn],bot,top;
int alltest=,ans,n,m,s,t; int addnode()
{
first[++node]=-;
return node;
} void addedge(int U,int V,int W)
{
edge++;
to[edge]=V,c[edge]=W,next[edge]=first[U],first[U]=edge;
edge++;
to[edge]=U,c[edge]=,next[edge]=first[V],first[V]=edge;
} bool bfs()
{
Q[bot=top=]=t,d[t]=,tag[t]=++TAG,can[t]=false;
while (bot<=top)
{
int cur=Q[bot++];
for (int i=first[cur]; i!=-; i=next[i])
if (c[i^]> && tag[to[i]]!=TAG)
{
tag[to[i]]=TAG,can[to[i]]=false;
d[to[i]]=d[cur]+,Q[++top]=to[i];
if (to[i]==s) return true;
}
}
return false;
} int dfs(int cur,int num)
{
if (cur==t) return num;
int tmp=num,k;
for (int i=first[cur]; i!=-; i=next[i])
if (c[i]> && tag[to[i]]==TAG && !can[to[i]] && d[to[i]]==d[cur]-)
{
k=dfs(to[i],min(num,c[i]));
if (k) num-=k,c[i]-=k,c[i^]+=k;
if (num==) break;
}
if (num) can[cur]=true;
return tmp-num;
} bool _input()
{
scanf("%d",&n);
s=addnode();
for (int i=; i<=n; i++) t=addnode();
t=addnode();
for (int i=; i<=n; i++) scanf("%d",&score[i]);
for (int i=; i<=n; i++) scanf("%d",&test[i]);
for (int i=; i<=n; i++)
for (int j=; j<=n; j++)
{
scanf("%d",&a[i][j]);
if (!a[i][j] || i>=j) continue;
test[i]-=a[i][j],test[j]-=a[i][j];
if (i==) score[]+=a[i][j];
else
{
alltest+=a[i][j];
int tmp=addnode();
addedge(i,tmp,a[i][j]);
addedge(j,tmp,a[i][j]);
addedge(tmp,t,a[i][j]);
}
}
score[]+=test[];
for (int i=; i<=n; i++)
{
if (score[i]>score[]) return false;
addedge(s,i,score[]-score[i]);
}
int ans=;
while (bfs()) ans+=dfs(s,maxn);
return ans==alltest;
} int main()
{
if (_input()) puts("YES");
else puts("NO");
return ;
}
SGU326_Perspective的更多相关文章
随机推荐
- ARP 地址分类 NAT技术
第1章 OSI回顾 1.1 TCP/IP协议族组成 应用层 主机到主机层 互联网层 网络接入层 1.2 总结应用层掌握的协议与端口号对应关系 http(80) telnet(23) ftp(2 ...
- Eclipse启动Tomcat错误:Several ports (8080, 8009) required by Tomcat v6.0 Server at localhost are already
Eclipse启动Tomcat错误: Several ports (8080, 8009) required by Tomcat v6.0 Server at localhost are alread ...
- 洛谷P1313 计算系数【快速幂+dp】
P1313 计算系数 题目描述 给定一个多项式(by+ax)^k,请求出多项式展开后x^n*y^m 项的系数. 输入输出格式 输入格式: 输入文件名为factor.in. 共一行,包含5 个整数,分别 ...
- jenkins+Gitlab持续集成环境配置教程
环境简介: Jenkins 2.156(本地win10) GitLab Enterprise Edition 10.1.4-ee (远程服务器) Apache Ant 1.9.13 (本地win10) ...
- POJ--3279(开关问题2个不同时间写的代码)
Fliptile Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 19730 Accepted: 7118 Descrip ...
- (2) English Learning
数词 数词有基数词和序数词两种.英语的数词可以作句子的主语.宾语.表语和定语. 基数词:表示数目的词叫基数词. 1. 英语中常用的基数词有:除了图片上的,还有以下一些 1000→one(a) th ...
- k8s环境搭建--基于minik8s方法
minik8s 安装 关闭selinux.开启ipv6 sudo bash selinux_ipv6.sh 下载kubectl和minikube 下载minikube,因为国外的源被墙了,所以只能用阿 ...
- mtr的用法场景
---引用自阿里云 mtr (My traceroute)也是几乎所有 Linux 发行版本预装的网络测试工具.他把 ping和 traceroute 的功能并入了同一个工具中,所以功能更强大. mt ...
- 配置tensorflow环境(anaconda+jupyter notebook)
很早之前,tensorflow环境之前我也曾装过,但是用的不是很舒服,很多问题都不明所以然.今天想要系统地学习一下tensorflow,于是又重新搭建了一遍,这次还是踩了不少坑.特此写下此文,供有兴趣 ...
- Python字典 (dict)
作者博文地址:http://www.cnblogs.com/spiritman/ 字典是Python语言中唯一的映射类型.字典对象是可变的,它是一个容器类型,支持异构.任意嵌套. 创建字典 语法:{k ...