题目链接:

http://codeforces.com/problemset/problem/77/C

C. Beavermuncher-0xFF

time limit per test:3 seconds
memory limit per test:256 megabytes
#### 问题描述
> "Eat a beaver, save a tree!" — That will be the motto of ecologists' urgent meeting in Beaverley Hills.
>
> And the whole point is that the population of beavers on the Earth has reached incredible sizes! Each day their number increases in several times and they don't even realize how much their unhealthy obsession with trees harms the nature and the humankind. The amount of oxygen in the atmosphere has dropped to 17 per cent and, as the best minds of the world think, that is not the end.
>
> In the middle of the 50-s of the previous century a group of soviet scientists succeed in foreseeing the situation with beavers and worked out a secret technology to clean territory. The technology bears a mysterious title "Beavermuncher-0xFF". Now the fate of the planet lies on the fragile shoulders of a small group of people who has dedicated their lives to science.
>
> The prototype is ready, you now need to urgently carry out its experiments in practice.
>
> You are given a tree, completely occupied by beavers. A tree is a connected undirected graph without cycles. The tree consists of n vertices, the i-th vertex contains ki beavers.
>
> "Beavermuncher-0xFF" works by the following principle: being at some vertex u, it can go to the vertex v, if they are connected by an edge, and eat exactly one beaver located at the vertex v. It is impossible to move to the vertex v if there are no beavers left in v. "Beavermuncher-0xFF" cannot just stand at some vertex and eat beavers in it. "Beavermuncher-0xFF" must move without stops.
>
> Why does the "Beavermuncher-0xFF" works like this? Because the developers have not provided place for the battery in it and eating beavers is necessary for converting their mass into pure energy.
>
> It is guaranteed that the beavers will be shocked by what is happening, which is why they will not be able to move from a vertex of the tree to another one. As for the "Beavermuncher-0xFF", it can move along each edge in both directions while conditions described above are fulfilled.
>
> The root of the tree is located at the vertex s. This means that the "Beavermuncher-0xFF" begins its mission at the vertex s and it must return there at the end of experiment, because no one is going to take it down from a high place.
>
> Determine the maximum number of beavers "Beavermuncher-0xFF" can eat and return to the starting vertex.
#### 输入
> The first line contains integer n — the number of vertices in the tree (1 ≤ n ≤ 105). The second line contains n integers ki (1 ≤ ki ≤ 105) — amounts of beavers on corresponding vertices. Following n - 1 lines describe the tree. Each line contains two integers separated by space. These integers represent two vertices connected by an edge. Vertices are numbered from 1 to n. The last line contains integer s — the number of the starting vertex (1 ≤ s ≤ n).
#### 输出
> Print the maximum number of beavers munched by the "Beavermuncher-0xFF".
>
> Please, do not use %lld specificator to write 64-bit integers in C++. It is preferred to use cout (also you may use %I64d).
#### 样例
> **sample input**
> 5
> 1 3 1 3 2
> 2 5
> 3 4
> 4 5
> 1 5
> 4
>
> **sample output**
> 6

题意

给你一颗树,树上每个点有ai个小球,现在你有一个机器人位于根节点,这个机器人每走到一个节点,就会吃掉这个节点上的一个小球(初始位置一开始不会吃),如果一个位置没有小球,这个机器人是过不去的,而且这个机器人不会停下来,现在问你从根节点开始吃,最后要求能回到根节点,能吃到的最多小球。

题解

贪心:

策略1:从u进入一个子节点v的时候,优先考虑吃掉v的子树,再考虑u,v之间来回吃。

策略2:对于u的所有子节点vi,定义sumv[vi]为吃掉最多的以vi为根的子树的球(并且回到vi)。那么我们对于u,优先考虑先吃sumv[vi]比较大的子树。

代码

#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
#include<algorithm>
using namespace std; const int maxn=1e5+10;
typedef __int64 LL; //cntv[v]:表示v节点的小球个数
//sumv[v]:表示吃完以v为根的子树并回到v能吃到的最多小球。
//remv[v]:表示吃完以v为根的子树并回到v能吃到的最多小球之后,v这个节点还剩下的小球个数。
LL cntv[maxn],sumv[maxn],remv[maxn];
int n,rt; void init(){
memset(remv,0,sizeof(remv));
memset(sumv,0,sizeof(sumv));
} vector<int> G[maxn];
void dfs(int u,int fa){
if(G[u].size()==1&&fa!=-1){
remv[u]=cntv[u];
sumv[u]=0;
}else{
priority_queue<LL> pq;
for(int i=0;i<G[u].size();i++){
int v=G[u][i];
if(v==fa) continue;
dfs(v,u);
pq.push(sumv[v]);
}
if(fa!=-1){
sumv[u]++; cntv[u]--;
}
while(cntv[u]&&!pq.empty()&&pq.top()){
LL t=pq.top(); pq.pop();
sumv[u]+=t;
cntv[u]--;
sumv[u]++;
}
for(int i=0;i<G[u].size()&&cntv[u];i++){
int v=G[u][i];
if(v==fa) continue;
if(remv[v]==0) continue;
if(cntv[u]>=remv[v]){
sumv[u]+=2*remv[v];
cntv[u]-=remv[v];
}else{
sumv[u]+=2*cntv[u];
cntv[u]=0;
}
}
remv[u]=cntv[u];
}
} int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&cntv[i]);
}
for(int i=1;i<n;i++){
int u,v;
scanf("%d%d",&u,&v);
G[u].push_back(v);
G[v].push_back(u);
}
scanf("%d",&rt);
dfs(rt,-1);
printf("%I64d\n",sumv[rt]);
return 0;
} /*
5
1 1 1 1 1
2 5
3 4
4 5
1 5
4 6
3 3 1 2 3 5
2 6
1 6
4 5
5 1
3 4
5
*/

Codeforces Beta Round #69 (Div. 1 Only) C. Beavermuncher-0xFF 树上贪心的更多相关文章

  1. Codeforces Beta Round #69 (Div. 2 Only)

    Codeforces Beta Round #69 (Div. 2 Only) http://codeforces.com/contest/80 A #include<bits/stdc++.h ...

  2. Codeforces Beta Round #85 (Div. 1 Only) A. Petya and Inequiations 贪心

    A. Petya and Inequiations Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest ...

  3. Codeforces Beta Round #63 (Div. 2)

    Codeforces Beta Round #63 (Div. 2) http://codeforces.com/contest/69 A #include<bits/stdc++.h> ...

  4. Codeforces Beta Round #80 (Div. 2 Only)【ABCD】

    Codeforces Beta Round #80 (Div. 2 Only) A Blackjack1 题意 一共52张扑克,A代表1或者11,2-10表示自己的数字,其他都表示10 现在你已经有一 ...

  5. Codeforces Beta Round #83 (Div. 1 Only)题解【ABCD】

    Codeforces Beta Round #83 (Div. 1 Only) A. Dorm Water Supply 题意 给你一个n点m边的图,保证每个点的入度和出度最多为1 如果这个点入度为0 ...

  6. Codeforces Beta Round #79 (Div. 2 Only)

    Codeforces Beta Round #79 (Div. 2 Only) http://codeforces.com/contest/102 A #include<bits/stdc++. ...

  7. Codeforces Beta Round #77 (Div. 2 Only)

    Codeforces Beta Round #77 (Div. 2 Only) http://codeforces.com/contest/96 A #include<bits/stdc++.h ...

  8. Codeforces Beta Round #76 (Div. 2 Only)

    Codeforces Beta Round #76 (Div. 2 Only) http://codeforces.com/contest/94 A #include<bits/stdc++.h ...

  9. Codeforces Beta Round #75 (Div. 2 Only)

    Codeforces Beta Round #75 (Div. 2 Only) http://codeforces.com/contest/92 A #include<iostream> ...

随机推荐

  1. eclipse指定启动的jdk

    原文:http://my.oschina.net/noday/blog/203987 到eclipse目录,打开eclipse.ini文件,在指定位置加入你的jdk相关文件(如下面示例配置中-vm配置 ...

  2. Entity Framework中的多个库操作批量提交、事务处理

    在Entity Framework 中使用SaveChanges()是很频繁的,单次修改或删除数据后调用SaveChanges()返回影响记录数. 要使用批量修改或者批量删除数据,就需要SaveCha ...

  3. Hadoop在win7下部署的问题

    问题: 为了测试方便所以在win7下部署了伪分布式hadoop运行环境,但是部署结束后在命令行运行hadoop命令创建一个用户文件目录时出现了一下情况: 系统找不到指定的批标签- make_comma ...

  4. 【Zend Studio】10.6.0版本设置默认编码为UTF-8

    1.打开Windows->Prefefences 2.找到Workspace->Text file encoding,修改为UTF-8,OK保存.

  5. 写一个函数,尽可能高效的,从一个标准 url 里取出文件的扩展名

    例如: http://www.sina.com.cn/abc/de/fg.php?id=1 需要取出 php 或 .php function getExt($url){ $arr=parse_url( ...

  6. 在GridControl控件中使用SearchLookUpEdit构建数据快速输入

    较早之前,曾经介绍了一篇文章<使用DataGridView数据窗口控件,构建用户快速输入体验>,介绍了在传统DataGridView中嵌入一个数据窗口进行选择列表,从而实现数据快速录入的操 ...

  7. 第二节:AppDomain

    CLR COM服务器初始化时,会创建一个AppDomain.AppDomain是一组程序集的逻辑容器.CLR初始化时创建的第一个AppDomain称为默认的AppDomain,这个默认的AppDoma ...

  8. python2.7爬取豆瓣电影top250并写入到TXT,Excel,MySQL数据库

    python2.7爬取豆瓣电影top250并分别写入到TXT,Excel,MySQL数据库 1.任务 爬取豆瓣电影top250 以txt文件保存 以Excel文档保存 将数据录入数据库 2.分析 电影 ...

  9. git的工作流程(分支合并)

    git支持很多种工作流程,我们采用的一般是这样,远程创建一个主分支,本地每人创建功能分支,日常工作流程如下: 去自己的工作分支$ git checkout work 工作.... 提交工作分支的修改$ ...

  10. ASP.NET内置对象之Request传递请求对象

    Request对象是HttpRequest类的一个实例,Request对象用于读取客户端在Web请求期间发送的HTTP值.Request对象常用的属性如下所示. q      QueryString: ...