hdu-1055(贪心)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1055
题意:给一棵树涂色,这棵树的每个节点都有自己的价值Ci,涂色的原则是只由这个节点的父节点涂色之后才能涂色(就是从根节点开始涂色)。
每次涂色用时1s,每个节点的涂色花费是Ci*Fi(Fi是从最开始到涂色到这个节点所花的时间)。对这棵树涂色的总涂色花费为sum,
求怎样涂色才能使sum最小。
思路:
结论:对于一个非根节点,它具有最大的权值,只有先访问完它的父节点再访问它才能使总花费最小。
1、建立一个结构体,c表示节点价值,fa表示父节点,t表示耗时,ans为总花费,初始化为sum(ci),表示每个节点自己涂色。
2、找到最大的非根节点m,然后找到它的父节点p,将m与p合并。ans+=vc[m].c*vc[p].t,表示从m到p这段路上的代价,然后
vc[p].c+=vc[m].c; vc[p].t+=vc[m].t; vc[p].w=1.0*vc[p].c/vc[p].t;
3、重复n-1次,因为有n个节点,n-1后合并为1个节点。
#include<iostream>
#include<cstdio>
#include<string>
using namespace std;
struct Node{
int fa,c,t;
double w;
};
Node vc[];
int fd(int n,int r)
{
int i,j,p;
double mx=-1.0;
for(i=;i<=n;i++)
{
if(i!=r&&vc[i].w>mx)
{
mx=vc[i].w;
p=i;
}
}
return p;
} int main(void)
{
int n,r,i,j,ans,p,m,x,y;
while(~scanf("%d %d",&n,&r))
{
if(n==&&r==) break;
ans=;
for(i=;i<=n;i++)
{
scanf("%d",&vc[i].c);
vc[i].t=;
vc[i].w=vc[i].c;
ans+=vc[i].c;
}
for(i=;i<n;i++)
{
scanf("%d %d",&x,&y);
vc[y].fa=x;
}
for(i=;i<n;i++)
{
m=fd(n,r);
p=vc[m].fa;
vc[m].w=;
ans+=vc[m].c*vc[p].t;
for(j=;j<=n;j++)
if(vc[j].fa==m) vc[j].fa=p;
vc[p].c+=vc[m].c;
vc[p].t+=vc[m].t;
vc[p].w=1.0*vc[p].c/vc[p].t;
}
printf("%d\n",ans);
}
return ;
}
hdu-1055(贪心)的更多相关文章
- Hdu 5289-Assignment 贪心,ST表
题目: http://acm.hdu.edu.cn/showproblem.php?pid=5289 Assignment Time Limit: 4000/2000 MS (Java/Others) ...
- hdu 4803 贪心/思维题
http://acm.hdu.edu.cn/showproblem.php?pid=4803 话说C++还卡精度么? G++ AC C++ WA 我自己的贪心策略错了 -- 就是尽量下键,然后上 ...
- hdu 1735(贪心) 统计字数
戳我穿越:http://acm.hdu.edu.cn/showproblem.php?pid=1735 对于贪心,二分,枚举等基础一定要掌握的很牢,要一步一个脚印走踏实 这是道贪心的题目,要有贪心的意 ...
- hdu 4974 贪心
http://acm.hdu.edu.cn/showproblem.php?pid=4974 n个人进行选秀,有一个人做裁判,每次有两人进行对决,裁判可以选择为两人打分,可以同时加上1分,或者单独为一 ...
- hdu 4982 贪心构造序列
http://acm.hdu.edu.cn/showproblem.php?pid=4982 给定n和k,求一个包含k个不相同正整数的集合,要求元素之和为n,并且其中k-1的元素的和为完全平方数 枚举 ...
- HDU 2307 贪心之活动安排问题
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2037 今年暑假不AC Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 1052 贪心+dp
http://acm.hdu.edu.cn/showproblem.php?pid=1052 Tian Ji -- The Horse Racing Time Limit: 2000/1000 MS ...
- HDU 2111 Saving HDU【贪心】
解题思路:排序后贪心,和fatmouse's trade 类似 Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: ...
- HDU 2831 (贪心)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2831 题目大意:植物大战僵尸.给定种植植物时间间隔t,以及每个僵尸的到达时间v,生命d.问是否能赢. ...
- HDU 3090 (贪心)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3090 题目大意:一共n段路.每段路每千米都会被抢劫一定数量,可以雇佣武士护卫m千米.问最少被抢劫数量 ...
随机推荐
- 迭代器iter()
from collections import Iterable print(isinstance({},iterable)) # 判断是否可迭代 from collections import It ...
- pycharm专业版(window)安装
1.官网下载 2. 3.直接finlsh 4. 5. https://pan.baidu.com/s/1mQcc98iJS5bnIyrC6097yA 密码:b1c1
- uiview animation 卡一下
原因:有个下载图片的地方在主线程执行,导致动画卡一下.
- 【转】.net 实现 语音搜索(仅限WebKit内核浏览器)
<input type="text" class="text" name="value_2" id="value_2&quo ...
- 值得推荐的C/C++开源框架和库
值得推荐的C/C++开源框架和库 转自:http://www.cnblogs.com/lidabo/p/5514155.html - 1. Webbench Webbench是一个在Linux下 ...
- 英语广播原声听力100篇MP3及听力原文
=============7.6================ Passage 031- 人工智能对人类的利与弊From a personal assistant, to doing searche ...
- java-- 的子类/父类构造方法 转
前提:父类和子类同时都有有参的构造函数和无参构造函数. Java中的子类初始化时初值为空.调用顺序为先调用父类无参构造函数,然后调用子类无参构造函数. java中的子类初始化时初值不为空.调用顺序为先 ...
- Game2048
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- MIUI 6的毛玻璃效果的技术实现(实时模糊)
说说MIUI 6的毛玻璃效果的技术实现. 很久以前我们的文件夹打开和最近任务等几个地方就使用了毛玻璃效果,在技术上讲就是背景模糊.应该是比iOS 7的使用要早很多.不过那时候我们使用的是先对背景截 ...
- IntelliJ IDEA教程
http://www.jetbrains.com/help/idea/meet-intellij-idea.html