ZZULIoj 1907 小火山的宝藏收益
Description
Input
Output
对于每一组数据输出一个整数, 代表小火山能获得的最大钱数。
Sample Input
2
1 1
20
3 1
4 5 6
1 2
2 3
Sample Output
20
6 树的模型,从树根开始出发,比较树根的值和树根所有直接相连的子节点的最大收益的和,输出大的值,求树根所有直接相连的子节点的最大收益和,要先求出每个子节点的最大收益,把每个子节点看成树根的问题,求法一样,用函数递归。
例如根节点为1,先比较1的值个2,5最大收益和,求2的最大收益要比较2的值和3,4的最大收益和,因为3,4没有子节点,所以最大收益为本身,所以2的子节点的最大收益和为5比2本身的值4大,所以2节点的最大收益为5,同样比较5节点最大收益为3,所以2,3的最大收益和为8小于1节点的值,1节点的值就是最大收益。
#include<cstdio>
#include<string.h>
int n,m,head[],flag[];
int num,mon[];
struct stu
{
int from,to,next;
}edge[];
void init()
{
memset(head,-,sizeof(head));
memset(flag,,sizeof(flag));
num=;
}
void add_edge(int u,int v)
{
edge[num].from=u;
edge[num].to=v;
edge[num].next=head[u];
head[u]=num++;
}
int dfs(int u) //函数作用为返回 max(当前节点的值,当前节点的子节点值的和)
{
flag[u]=;
int money=mon[u]; //记录当前节点的值
int ans=,i,v; //ans表示子节点的和
for(i = head[u] ; i != - ; i=edge[i].next)
{
v=edge[i].to;
if(!flag[v])
{
ans+=dfs(v); //求子节点值的和,dfs返回 max(子节点值,子节点的字节的值的和)
flag[v]=;
}
}
return ans=ans>money?ans:money; //返回当前节点和子节点值较大的
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int a,b,i;
int n,s,ans;
scanf("%d %d",&n,&s);
init();
for(i = ; i <= n ; i++)
{
scanf("%d",&mon[i]);
}
for(i = ; i < n- ; i++)
{
scanf("%d %d",&a,&b);
add_edge(a,b);
add_edge(b,a);
}
ans=dfs(s);
printf("%d\n",ans);
}
}
ZZULIoj 1907 小火山的宝藏收益的更多相关文章
- (zzuli)1907 小火山的宝藏收益
Description 进去宝藏后, 小火山发现宝藏有N个房间,且这n个房间通过N-1道门联通. 每一个房间都有一个价值为Ai的宝藏, 但是每一个房间也都存在一个机关.如果小火山取走了这个房间的宝藏, ...
- zzuli 1907: 小火山的宝藏收益 邻接表+DFS
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 113 Solved: 24 SubmitStatusWeb Board Description ...
- zzulioj 1907小火山的宝藏交易(dfs记忆化搜索)
#include <stdio.h> #include <algorithm> #include <string.h> #include <vector> ...
- ZZULIoj 1912 小火山的爱情密码
Description 小火山获得了一个字符串,然而大火山让小火山从里面截取一段字符串,并且让小火山截取的字符串满足一些字符达到一定数量. 小火山觉得很容易,但是他想要知道他至少得截取多长的字符串. ...
- ZZULIoj 1913: 小火山的计算能力
Description 别人说小火山的计算能力不行,小火山很生气,于是他想证明自己,现在有一个表达式,他想计算出来. Input 首先是一个t(1<=20)表示测试组数.然后一个表达式,表达式长 ...
- ZZULIoj 1908 小火山的围棋梦想
Description 小火山最近喜欢上了围棋. 对于围棋,其实小火山是一窍不通的.现在棋盘上,有很多小火山的棋子. 如果棋盘上有这样的一个位置, 那么这个位置也会变成小火山 的棋子:这样的位 ...
- zzuliOJ 1904小火山的股票交易;
#include <stdio.h> #include <algorithm> #include <string.h> using namespace std; # ...
- zzuli 1905 小火山的跳子游戏
Description 小火山和火山火山在一块玩跳子游戏.规则如下: 1:跳子的起始位置为0,棋盘大小从1到N 2:每次跳子跳k步. 例如当前位置为i, 那么下一步为i + k 3:跳 ...
- 【数学+思维】ZZULIOJ 1531: 小L的区间求和
题目链接 题目描述 在给定的一个整数序列中,小L希望找到一个连续的区间,这个区间的和能够被k整除,请你帮小L算一下满足条件的最长的区间长度是多少. 输入 第一行输入两个整数n.k.(1 <= n ...
随机推荐
- 《统计学习方法》笔记九 EM算法及其推广
本系列笔记内容参考来源为李航<统计学习方法> EM算法是一种迭代算法,用于含有隐变量的概率模型参数的极大似然估计或极大后验概率估计.迭代由 (1)E步:求期望 (2)M步:求极大 组成,称 ...
- JQuery基础知识梳理篇
这周没事,优化线上项目,因为前端都在赶项目,我又若菜.于是前端数据展示也要自己来.看javascript看到吐,决定梳理一下Jquery基础知识.敲黑板) 闲扯结束,进入正题. 选择器 介绍 jque ...
- bzoj3626: [LNOI2014]LCA奇技淫巧+树剖+线段树
题目求[a,b]到c的lca深度之和 显然是一个满足区间减法的操作 于是简化为 [1,b]到c的lca深度之和 (然并卵╮(╯▽╰)╭)然后就用奇技淫巧发现 a和b的lca深度=先把根节点到a的路 ...
- DiscuzX2.5密码错误次数过多,请 15 分钟后重新登录的修改办法
source\function function_login.php $return = (!$login || (TIMESTAMP - $login['lastupdate'] > )) ? ...
- Chess 模拟
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6114 Problem Description 車是中国象棋中的一种棋子,它能攻击同一行或同一列中没有其他棋 ...
- body和普通div背景图宽高百分比的区别
body和普通div背景图的区别 background: url(//m.360buyimg.com/mobilecms/s220x220_jfs/t2746/167/831241799/29915 ...
- Actionbar Demo
源码下载:http://download.csdn.net/detail/bx276626237/8874119
- ThreadLocal遇到线程池时, 各线程间的数据会互相干扰, 串来串去
最近遇到一个比较隐蔽而又简单地问题,在使用ThreadLocal时发现出现多个线程中值串来串去,排查一番,确定问题为线程池的问题,线程池中的线程是会重复利用的,而ThreadLocal是用线程来做Ke ...
- java+spring 执行器
A 通过MethodInvokingJobDetailFactoryBean类实现 spring配置文件里增加执行器配置 <bean id="ammoDue" class=& ...
- POJ 3140 Contestants Division (树形DP,简单)
题意: 有n个城市,构成一棵树,每个城市有v个人,要求断开树上的一条边,使得两个连通分量中的人数之差最小.问差的绝对值.(注意本题的M是没有用的,因为所给的必定是一棵树,边数M必定是n-1) 思路: ...
