【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划
【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划
题目
Description

Input

Output
对于每组数据,输出一个整数,表示达到“平衡”状态所需的最小代价。
Sample Input
2
3
6 1 5
1 2 1
2 3 2
5
4 5 4 3 2
1 3 1
1 2 2
2 4 3
2 5 4
Sample Output
4
4
Data Constraint
对于20%的数据,N<=15
对于100%的数据,T<=10,N<=100,0<=si<=10000,1<=X,Y<=N,1<=Z<=10000。
Hint
对于第一组数据,从城市1到城市2运输2桶石油,代价为\(1*2=2\);从城市3往城市2运输1桶石油,代价为\(2*1=2\)。此时三个城市储备量都为4桶,该状态的平衡度为0。
对于第二组数据,从城市2到城市5运输1桶石油,代价为\(1*4=4\);此时五个城市储备量为(4,4,4,3,3),该状态的非平衡度为1.2,是能达到的所有状态的最小值。
题解
题意
给出一棵树,有边权
定义一个非平衡度(如题)
问如何运输使得非平衡度最小,且代价最低
分析
很容易发现非平衡度最小有两种情况
- 当\(sum\%n=0\),答案为\(\dfrac{sum}{n}\)
- 若不为0,答案为\(\left \lfloor\dfrac{sum}n{}\right \rfloor\)或\(\left \lfloor\dfrac{sum}n{}\right \rfloor+1\)
那么容易想到最小费用最大流
- 所有点往源点连一条流量为油桶数量,费用为0的边
- 所有点往汇点连一条流量为\(\left \lfloor\dfrac{sum}n{}\right \rfloor\),费用为0的边
- 对于读入的点,连流量正无穷,费用读入的边(注意是双向,加上反向弧总共4条)
然后跑一遍最小费用最大流
随后把所有连向汇点的边流量加一
再跑一遍
两次答案之和即为答案
Code
#include<bits/stdc++.h>
#define rg register
#define inf 999999999999
using namespace std;
struct node
{
long long to,next,val,flow;
}a[5005];
long long t,n,x,y,z,S,T,ans,ans1,tot,sum,head[5005],bj[5005],dis[5005],sy[5005];
inline void add(long long x,long long y,long long z,long long v)
{
a[tot].to=y;
a[tot].flow=z;
a[tot].val=v;
a[tot].next=head[x];
head[x]=tot;
++tot;
}
inline long long OK()
{
long long plus=inf;
for (rg long long i=0;i<=n+2;++i)
if (bj[i])
for (rg long long j=head[i];j!=-1;j=a[j].next)
if (!bj[a[j].to]&&a[j].flow) plus=min(plus,dis[a[j].to]+a[j].val-dis[i]);
if (plus==inf) return 0;
for (rg long long i=0;i<=n+2;++i)
{
if (bj[i])
{
bj[i]=0;
dis[i]+=plus;
}
}
return 1;
}
inline long long wwl(long long now,long long ss)
{
if (now==T)
{
ans1+=dis[S]*ss;
return ss;
}
bj[now]=1;
long long u,x;
for (rg long long i=head[now];i!=-1;i=a[i].next)
{
u=a[i].to;
if (!bj[u]&&dis[u]+a[i].val==dis[now]&&a[i].flow)
{
x=wwl(u,min(ss,a[i].flow));
if (x)
{
a[i].flow-=x;
a[i^1].flow+=x;
return x;
}
}
}
return 0;
}
inline void ffl()
{
long long q;
while (OK())
{
q=wwl(S,inf);
while (q)
{
memset(bj,0,sizeof(bj));
q=wwl(S,inf);
}
}
}
int main()
{
freopen("test.in","r",stdin);
freopen("test.out","w",stdout);
scanf("%lld",&t);
while (t--)
{
memset(head,-1,sizeof(head));
memset(a,0,sizeof(a));
memset(dis,0,sizeof(dis));
memset(bj,0,sizeof(bj));
scanf("%lld",&n);
S=n+1;
T=n+2;
ans=sum=ans1=0;
tot=0;
for (rg long long i=1;i<=n;++i)
{
scanf("%lld",&x);
add(S,i,x,0);
add(i,S,0,0);
sum+=x;
}
for (rg long long i=1;i<n;++i)
{
scanf("%lld%lld%lld",&x,&y,&z);
add(x,y,inf,z);
add(y,x,0,-z);
add(y,x,inf,z);
add(x,y,0,-z);
}
sum/=n;
for (rg long long i=1;i<=n;++i)
{
add(i,T,sum,0);
add(T,i,0,0);
}
bj[S]=1;
ffl();
for (rg long long i=2;i<=tot;++i)
if (a[i].to==T)
a[i].flow++;
bj[S]=1;
ffl();
printf("%lld\n",ans1);
}
return 0;
}
【GDKOI2014】JZOJ2020年8月13日提高组T2 石油储备计划的更多相关文章
- 【GDKOI2014】JZOJ2020年8月13日提高组T4 内存分配
[GDKOI2014]JZOJ2020年8月13日提高组T4 内存分配 题目 Description Input Output 输出m行,每行一个整数,代表输入中每次程序变化后系统所需要的空闲内存单位 ...
- 【GDKOI2014】JZOJ2020年8月13日提高组T3 壕壕的寒假作业
[GDKOI2014]JZOJ2020年8月13日提高组T3 壕壕的寒假作业 题目 Description Input Output 输出n行.第i行输出两个整数,分别表示第i份作业最早完成的时刻以及 ...
- 【GDKOI2014】JZOJ2020年8月13日提高组T1 阶乘
[GDKOI2014]JZOJ2020年8月13日提高组T1 阶乘 题目 Description Input 第一行有一个正整数T,表示测试数据的组数. 接下来的T行,每行输入两个十进制整数n和bas ...
- JZOJ2020年8月13日提高组反思
JZOJ2020年8月13日提高组反思 T1 打了3h+,然后自己的小数据都没过 果断选择交对拍的暴力 下次还是注意时间吧 T2 一下三题都没时间打了 看了题目觉得特别烦人(有式子) 再看发现式子类似 ...
- JZOJ2020年8月11日提高组T2 宝石
JZOJ2020年8月11日提高组T2 宝石 题目 Description 见上帝动了恻隐之心,天后也想显示一下慈悲之怀,随即从口袋中取出一块魔术方巾,让身边的美神维纳斯拿到后堂的屏风上去试试,屏风是 ...
- 【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你
[五校联考1day2]JZOJ2020年8月12日提高组T2 我想大声告诉你 题目 Description 因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一 ...
- 【佛山市选2013】JZOJ2020年8月7日提高组T2 树环转换
[佛山市选2013]JZOJ2020年8月7日提高组T2 树环转换 题目 描述 给定一棵N个节点的树,去掉这棵树的一条边需要消耗值1,为这个图的两个点加上一条边也需要消耗值1.树的节点编号从1开始.在 ...
- 【NOIP2015模拟11.4】JZOJ2020年8月6日提高组T2 最优交换
[NOIP2015模拟11.4]JZOJ2020年8月6日提高组T2 最优交换 题目 题解 题意 有一个长度为\(n\)的正整数 最多可以进行\(k\)次操作 每次操作交换相邻两个位置上的数 问可以得 ...
- JZOJ2020年8月11日提高组T4 景点中心
JZOJ2020年8月11日提高组T4 景点中心 题目 Description 话说宁波市的中小学生在镇海中学参加计算机程序设计比赛,比赛之余,他们在镇海中学的各个景点参观.镇海中学共有n个景点,每个 ...
随机推荐
- React react-redux props或state更新视图无法重新渲染问题
记录学习React时自己是如何挖坑把自己埋了的过程:children以及其它props被修改时相关组件无法重新渲染(做了两天) 父组件代码: class UserHome extends Compon ...
- 「SHOI2014」三叉神经树
「SHOI2014」三叉神经树 给你一颗由\(n\)个非叶子结点和\(2n+1\)个叶子结点构成的完全三叉树,每个叶子结点有一个输出:\(0\)或\(1\),每个非叶子结点的输出为自己的叶子结点中较多 ...
- Java_流相关
java.io包中重要的5个类3个接口 类名 说明 File 文件类 InputStream 字节流输入 OutputStream 字节流输出 Reader 字符输入流 Writer 字符输出流 Cl ...
- 解Bug之路-NAT引发的性能瓶颈
解Bug之路-NAT引发的性能瓶颈 笔者最近解决了一个非常曲折的问题,从抓包开始一路排查到不同内核版本间的细微差异,最后才完美解释了所有的现象.在这里将整个过程写成博文记录下来,希望能够对读者有所帮助 ...
- JIRA、Confluence等产品明年2月停售本地化版本,将影响中国近90%的客户!
作为目前应用最为广泛的软件开发管理软件,JIRA.Confluence等产品几乎被所有的科技型公司所应用.我们的每天的任务管理.文档编写等工作几乎都在这些软件的帮助下进行和管理.当然我也不例外,在读书 ...
- 手写atoi、strcpy、strcat
一:实现atoi函数 1 #include<iostream> 2 3 using namespace std; 4 5 int atoi_my(const char *str) 6 { ...
- JVM初识
先来看一张图 首先jvm是什么? jvm是java运行环境的一部分,是一种以软件模式虚拟出来的一个计算机系统. 如上图所示,JVM 主要分为三个子系统:类加载器.运行时数据区和执行引擎. 类加载器子系 ...
- Python_selenium案例:
selenium案例 #coding=utf-8 #select下拉框处理 from selenium import webdriver from selenium.webdriver.common. ...
- 工作流(workflow)
1,JBPM 工作流(开源历史悠久) 2,activity 工作流(开源历史悠久) 3,workable 工作流(功能比较强大,但是开源维护缓慢,比较注重商业化) 以上三个是主流的工作流
- apiAutoTest-更新2020/11/23
原始版本 简书:https://www.jianshu.com/p/6bfaca87a93b 博客园:https://www.cnblogs.com/zy7y/p/13426816.html test ...