bzoj 1825: [JSOI2010]蔬菜庆典
1825: [JSOI2010]蔬菜庆典
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 112 Solved: 45
[Submit][Status][Discuss]
Description

Input

Output
Sample Input
-1 3
1 2
1 1
3 2
3 2
5
-1 3
1 2
1 1
3 2
3 3
0
Sample Output
+inf
HINT

简化版题意:
给出一棵有根树,每个点有一个权值v,可以对一个有父亲并且又有儿子的节点选择一个儿子进行一次操作使$v[x]=v[fa[x]]+v[son[x]]-v[x]$。
问无限制使用这种操作后树上的权值和最大为多少。
参照样例,显然当某一时刻一个非根节点有两个不同权值的儿子时答案就是正无穷。
假设这个点的权值为A,父亲为B,权值小的孩子为C,大的为D。
第一次 A'=(B+C-A) 第二次 A''=B+D-A'=B+D-B-C+A=A+D-C>A
然后考虑怎么构造出这种情况。
因为根节点是不会变的,所以对于1的每一个儿子可以分开处理,设为函数solve(x)。
如果某个点有两个儿子不同那么就不需要构造直接返回inf。
如果每个点的$v[fa[x]]+v[son[x]]$都等于$2v[x]$显然这棵树的权值是固定的,返回整棵树的权值。
那么现在存在一个点$v[fa[x]]+v[son[x]]!=2[v[x]]$,这个点的权值可以变化,那么说明这棵树的非叶节点的权值都可以变化(递归考虑,一个点的权值要么本身就能变化,那么它父亲或儿子变化后它可以变化),此时如果答案不为inf,这棵树只能是一条链,或者链上的最后一个点可以有多个叶儿子。
两种情况没有区别,考虑一条链怎么做。
不妨让它长这样:
....A B C.....
对B操作,我们从两个视角看:
A: B'=A+(C-B)
C: B'=C-(B-A)
B'-A=(C-B)
C-B'=(B-A)
其实就是差分序列的相邻两项交换了位置。
然后做法就很明了了。。。
为了让和尽量大,我们把差分序列排个序就好啦>_<
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 200005
#define int long long
#define inf 0x3f3f3f3f
using namespace std;
int head[N],ver[N],nxt[N],tot;
int son[N];
void add(int a,int b)
{
tot++;nxt[tot]=head[a];head[a]=tot;ver[tot]=b;return ;
}
int n;
int p[N],v[N];
bool flag,lian,flag2,flag3;
int sum[N],ss;
void dfs(int x)
{
int pre=inf;
if(!head[x])ss+=v[x];
if(p[x]!=1&&son[x]!=0&&son[p[x]]>=2)flag3=1;
for(int i=head[x];i;i=nxt[i])
{
if(son[x]>1)lian=1;
if(pre!=inf&&v[ver[i]]!=pre)flag=1;
if(v[p[x]]+v[ver[i]]!=2*v[x])flag2=1;
pre=v[ver[i]];
dfs(ver[i]);
sum[x]+=sum[ver[i]];
}
sum[x]+=v[x];
return ;
}
int st[N],top;
bool cmp(int x,int y)
{
return x>y;
}
int solve(int x)
{
flag=0;lian=0;flag2=0;flag3=0;ss=0;
dfs(x);
if(flag||(lian&&flag2&&flag3))return 0;
if(lian&&flag3)return sum[x];
top=0;
for(int i=x;;i=ver[head[i]])
{
st[++top]=v[i]-v[p[i]];
if(!head[i])break;
}
sort(st+1,st+top+1,cmp);
int now=v[1];
int sm=0;
for(int i=1;i<top;i++)
{
now+=st[i];
sm+=now;
}
return sm+ss;
}
signed main()
{
while(~scanf("%lld",&n))
{
if(n==0)break;
for(int i=1;i<=n;i++)
{
scanf("%lld%lld",&p[i],&v[i]);
if(p[i]!=-1)add(p[i],i),son[p[i]]++;
}
int ans=0,ts=0;
for(int i=head[1];i;i=nxt[i])
{
int tmp=solve(ver[i]);
if(flag||(lian&&flag2&&flag3))ts=1;
ans+=tmp;
}
if(ts)puts("+inf");
else printf("%lld\n",ans+v[1]);
tot=0;
for(int i=1;i<=n;i++)head[i]=sum[i]=p[i]=v[i]=son[i]=0;
}
return 0;
}
bzoj 1825: [JSOI2010]蔬菜庆典的更多相关文章
- bzoj1825: [JSOI2010]蔬菜庆典
Description Input Output 对于每组数据,输出一行.若蔬菜的总价能无限制增大,输出"+inf"(不含引号).否则输出一个整数,表示所有蔬菜的最大总价. 首 ...
- BZOJ 2208: [Jsoi2010]连通数 tarjan bitset
2208: [Jsoi2010]连通数 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...
- BZOJ 2208: [Jsoi2010]连通数( DFS )
n只有2000,直接DFS就可以过了... -------------------------------------------------------------------------- #in ...
- BZOJ 1820: [JSOI2010]Express Service 快递服务( dp )
dp(i,j,k)表示在处理第i个业务, 另外2个在j,k处. 第一维可以滚动... --------------------------------------------------------- ...
- BZOJ 1823: [JSOI2010]满汉全席( 2-sat )
2-sat...假如一个评委喜好的2样中..其中一样没做, 那另一样就一定要做, 这样去建图..然后跑tarjan. 时间复杂度O((n+m)*K) ------------------------- ...
- bzoj 2208 [Jsoi2010]连通数
2208: [Jsoi2010]连通数 Time Limit: 20 Sec Memory Limit: 512 MB Description Input 输入数据第一行是图顶点的数量,一个正整数N ...
- 【刷题】BZOJ 4946 [Noi2017]蔬菜
Description http://www.lydsy.com/JudgeOnline/upload/Noi2017D2.pdf Solution 网上大部分都是并查集写法,但是有大神写了非并查集写 ...
- BZOJ.4946.[NOI2017]蔬菜(贪心 离线)
题目链接 因为有删除,考虑倒序处理某个p的询问. 那么每天删除xi的蔬菜就变成了每天运来xi的蔬菜.那么我们取当前最优的即可,早取晚取都一样,不需要留给后面取,还能给后面更优的留出空间. 这样就只需考 ...
- bzoj 1823: [JSOI2010]满汉全席 && bzoj 2199 : [Usaco2011 Jan]奶牛议会 2-sat
noip之前学的内容了,看到题竟然忘了怎么建图了,复习一下. 2-sat 大概是对于每个元素,它有0和1两种选择,必须选一个但不能同时选.这之间又有一些二元关系,比如x&y=1等等... 先把 ...
随机推荐
- 天马行空云计算(二)-Hardware&Hypervisor介绍
天马行空云计算系列一介绍了总体抽象视图,本篇展开Hardware&Hypervisor 介绍.如下是介绍大纲: 本篇将基于上述架构从如下方面介绍说明 Linux设备驱动 因为上述提到的一些硬件 ...
- Windows下的ROUGE文本测评工具基本安装
需要的安装包: rouge1.5.5:https://pan.baidu.com/s/1B7-LYn1lZKC8f51yXxNK9w Strawberry Perl :http://strawberr ...
- 满帮集团CEO:未来将向“智慧型”公司转变,要成为一家生态公司
谁都想成为下一个滴滴.显然,王刚也希望在物流业,货车帮与运满满在合并后,能够企及滴滴的高度. 货车帮与运满满,都曾是货运物流领域的翘楚,也因为业务的竞争关系有过水火不容厮杀.但最终还是在资本与地方政府 ...
- 编写webpack 插件
Webpack插件为第三方开发者释放了Webpack的最大可能性.利用多级回调开发者可以把他们自己的需要的功能引入到Webpack里面来.Build插件比Build loader 更进一步.因为你需要 ...
- python之multiprocessing创建进程
python的multiprocessing模块是用来创建多进程的,下面对multiprocessing总结一下使用记录. multiprocessing创建多进程在windows和linux系统下的 ...
- ES6的新特性(23)——ArrayBuffer
ArrayBuffer ArrayBuffer对象.TypedArray视图和DataView视图是 JavaScript 操作二进制数据的一个接口.这些对象早就存在,属于独立的规格(2011 年 2 ...
- Scrum Meeting 11.06
成员 今日任务 明日计划 用时 徐越 学习ListView+simpleAdapter,actionBar.阅读并修改前端代码 继续修改前端代码.完善数据库 4h 赵庶宏 构建后端数据库,进行完善 ...
- 我是IT小小鸟读后感
<我是一只IT小小鸟>一只是我想读list中一个本,但是上次去当当买的时候,竟然缺货了...昨天监考,实在无聊,就上网看电子书了,一天就看完了,看得有点仓促,所以理解估计不深. 1.刘帅: ...
- Linux操作系统(三)
文件系统: boot sector:记录引导文件 sb: super block 每个文件系统只有一个sb,其余black group均是它的备份 读写文件会进入到inode operation vf ...
- Oracle 默认的driectory 目录
1. 写导出命令忘记加directory参数了.. 查了一下: select directory_path from all_directories c:\cwdata\ C:\app\Adminis ...