这题其实不难想到

Description

link

题意太长了,概括不来,去题库里扫一眼吧(但是很好懂)

Solution

\[Begin
\]

考虑一个事情:每一个队伍的输局是没有用的

贪心一下,让每个队伍把剩下的比赛赢下来的时候,最有可能夺冠

设最终当前队赢得的场数的 \(maxx\)

接下来我们考虑让剩下的比赛怎么胜负

非这个队在剩下的比赛中的最大胜场数不得大于 \(maxx-w_j\) ,其中$j \in[1,n] $且 \(j!=i\)

然后我们建图

每一场比赛都会让胜者的胜利场次加 \(1\) ,把 比赛的场次当成一个点,队伍当成一个点

每场比赛向队伍分别连边,边权为 \(1\) ,源点向 比赛场次连,然后队伍向汇点连

跑网络流就行了(或者这玩意就是个二分图完美匹配??)

\[Finish
\]

Code

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define cl(x) memset(x, 0, sizeof(x))
namespace yspm {
inline int read() {
int res = 0, f = 1;
char k;
while (!isdigit(k = getchar()))
if (k == '-')
f = -1;
while (isdigit(k)) res = res * 10 + k - '0', k = getchar();
return res * f;
}
int n, s, t, tot;
const int N = 1e4 + 10;
int head[N], w[N], a[N][N], id[N][N], dep[N], cnt = 1;
struct node {
int nxt, to, lim;
} e[N << 1];
inline void add2(int u, int v, int w) {
e[++cnt].lim = w;
e[cnt].nxt = head[u];
e[cnt].to = v;
return head[u] = cnt, void();
}
inline void add1(int u, int v, int w) {
add2(u, v, w);
add2(v, u, 0);
return;
}
queue<int> q;
inline bool bfs() {
cl(dep);
dep[s] = 1;
q.push(s);
while (q.size()) {
int fr = q.front();
q.pop();
for (int i = head[fr]; i; i = e[i].nxt) {
int t = e[i].to;
if (!dep[t] && e[i].lim)
dep[t] = dep[fr] + 1, q.push(t);
}
}
return dep[t];
}
inline int dfs(int now, int in) {
if (now == t)
return in;
for (int i = head[now]; i && in; i = e[i].nxt) {
int t = e[i].to;
if (!e[i].lim || dep[t] != dep[now] + 1)
continue;
int res = dfs(t, min(e[i].lim, in));
e[i].lim -= res;
e[i ^ 1].lim += res;
if (res)
return res;
}
return 0;
}
inline void solve(int x) {
cl(head);
cnt = 1;
cl(e);
int maxx = w[x], tmp = 0;
for (int i = 1; i <= n; ++i) maxx += a[x][i];
for (int i = 1; i <= n; ++i) {
if (i == x)
continue;
if (w[i] > maxx)
return;
add1(i, t, maxx - w[i]);
for (int j = 1; j < i; ++j) {
if (j != x && a[i][j]) {
add1(s, id[i][j], a[i][j]), tmp += a[i][j];
add1(id[i][j], i, a[i][j]);
add1(id[i][j], j, a[i][j]);
}
}
}
int sum = 0, d;
while (bfs()) {
while (d = dfs(s, 1e15 + 10)) sum += d;
}
if (sum == tmp)
printf("%lld ", x);
return;
}
signed main() {
n = read();
s = n + 1, t = n + 2, tot = n + 2;
for (int i = 1, k; i <= n; ++i) w[i] = read(), k = read();
for (int i = 1; i <= n; ++i)
for (int j = 1; j <= n; ++j) a[i][j] = read();
for (int i = 1; i <= n; ++i)
for (int j = 1; j < i; ++j) id[i][j] = ++tot;
for (int i = 1; i <= n; ++i) solve(i);
puts("");
return 0;
}
} // namespace yspm
signed main() { return yspm::main(); }

格式化了,代码很好懂

LGOJ1264 K-联赛的更多相关文章

  1. 用原始方法解析复杂字符串,json一定要用JsonMapper么?

    经常采集数据,肯定会碰到解析字符串,包括整个页面的html,或者json以及一些不标准的json格式... 以前用json序列化,有时候需要实体类,有的时候没有,比较麻烦,听说可以用JsonMappe ...

  2. django模型操作

    Django-Model操作数据库(增删改查.连表结构) 一.数据库操作 1.创建model表        

  3. “盛大游戏杯”第15届上海大学程序设计联赛夏季赛暨上海高校金马五校赛题解&&源码【A,水,B,水,C,水,D,快速幂,E,优先队列,F,暴力,G,贪心+排序,H,STL乱搞,I,尼姆博弈,J,差分dp,K,二分+排序,L,矩阵快速幂,M,线段树区间更新+Lazy思想,N,超级快速幂+扩展欧里几德,O,BFS】

    黑白图像直方图 发布时间: 2017年7月9日 18:30   最后更新: 2017年7月10日 21:08   时间限制: 1000ms   内存限制: 128M 描述 在一个矩形的灰度图像上,每个 ...

  4. 使用 Python 抓取欧洲足球联赛数据

    Web Scraping在大数据时代,一切都要用数据来说话,大数据处理的过程一般需要经过以下的几个步骤    数据的采集和获取    数据的清洗,抽取,变形和装载    数据的分析,探索和预测    ...

  5. 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中

    题目名称 正确答案  序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...

  6. Codevs 1138 聪明的质监员 2011年NOIP全国联赛提高组

    1138 聪明的质监员 2011年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 小 T 是一名质量监督员, ...

  7. Codevs 1217 借教室 2012年NOIP全国联赛提高组

    1217 借教室 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在大学期间,经常需要租借教 ...

  8. Codevs 3287 货车运输 2013年NOIP全国联赛提高组(带权LCA+并查集+最大生成树)

    3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description A 国有 n 座 ...

  9. Codevs 1140 Jam的计数法 2006年NOIP全国联赛普及组

    1140 Jam的计数法 2006年NOIP全国联赛普及组 传送门 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description Jam是个喜欢标 ...

  10. 【Never Stop】联赛集训记录

    始于10/01/2017. Day I: T2图论,没想到.T3谜一样DP(是从来没意识到还可以这样). rank10. 下午刷了点题,CDQ也只打出一个板子,感觉自己不在状态? ========== ...

随机推荐

  1. jqGrid 添加 合计行 footDate

    jQuery(table_id).jqGrid({ url : url,//组件创建完成之后请求数据的url datatype : "json",//请求数据返回的类型.可选jso ...

  2. Java交换数据为何不起作用原因分析

    一.概述 目前各类语言中向函数传递参数的类型分为三种: 按值传递 按引用传递 按指针传递 其中按值传递表示方法(函数)接收的是调用者提供的变量的拷贝,不改变参数的值:按引用传递表示方法(函数)接收的调 ...

  3. UVA - 557 Burger(汉堡)(dp+概率)

    题意:有n个牛肉堡和n个鸡肉堡给2n个孩子吃.每个孩子在吃之前都要抛硬币,正面吃牛肉堡,反面吃鸡肉堡.如果剩下的所有汉堡都一样,则不用抛硬币.求最后两个孩子吃到相同汉堡的概率. 分析: 1.先求最后两 ...

  4. UVA - 11582 Colossal Fibonacci Numbers! (巨大的斐波那契数!)

    题意:输入两个非负整数a.b和正整数n(0<=a,b<264,1<=n<=1000),你的任务是计算f(ab)除以n的余数,f(0) = 0, f(1) = 1,且对于所有非负 ...

  5. 安装与配置windbg的symbol(符号)

    http://msdn.microsoft.com/en-us/windows/hardware/gg463028.aspx  windows symbols下载地址 本篇是新手自己写的一点心得.建议 ...

  6. ORACLE时间相关问题

    一.遇到一个情况数据库存入的时间格式为20180831154546,需要将其转化为日期时分秒格式的. to_date('20180831154546', 'yyyy-mm-dd hh24:mi:ss' ...

  7. 洛谷 P1470 最长前缀 Longest Prefix

    题目传送门 解题思路: 其实思路没那么难,就是题面不好理解,解释一下题面吧. 就是在下面的字符串中找一个子串,使其以某种方式被分解后,每部分都是上面所给集合中的元素. AC代码: #include&l ...

  8. BGP联邦配置

    BGP联盟建立: ①:启用BGP进程. ②:关闭同步与自动汇总. ③:router-id ④:公布自己所属联盟.——confederation identifier ID ⑤:表达自己的与其他对等(p ...

  9. windows elasticsearch-head插件安装教程

    elasticsearch-head下载地址:https://github.com/mobz/elasticsearch-head 1.git下载 git clone git://github.com ...

  10. 2020PHP面试-Redis篇

    一.Redis 数据类型 1. string 字符型. 2.hash hash  结构化的对象.  key不可重复 3.list 队列  lpush rpop  lpop rpush 4. set 集 ...