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 ...
随机推荐
- 简单总结ConcurrentHashMap
一.HashTable hashTable是一个线程安全的容器,是线程安全版本的HashMap.但它的底层是和HashMap一样的,只是在方法上都加上了synchronized关键字. 这样子有什么后 ...
- php设计模式学习之工厂模式
我的认为:所为工厂模式是事先有一系类class,一个工厂类' 工厂类根据不同的参数创建不同的对象,调用各自的方法; php利用工厂模式实现计算器: ?php /** * Created by PhpS ...
- 初始Activity启动模式
之前断断续续接触了解过Android activity,可是从没有应用过,这次因为一个严重缺陷再次认识Activity的启动模式,相比以前理解更深入了,以后使用检查也就更方便了. 任务栈(Task S ...
- 如何查找Oracle某列值相同的字段
相关的sql语句如下 select xm_guidfrom T_NZYDKgroup by xm_guidhaving count (*)>1
- 浅谈Hibernate中的三种数据状态
Hibernate中的三种数据状态:临时.持久.游离 1.临时态(瞬时态) 不存在于session中,也不存在于数据库中的数据,被称为临时态. 数据库中没有数据与之对应,超过作用域会被JVM垃圾回收器 ...
- kafka客户端发布record(消息)
kafka客户端发布record(消息)到kafka集群. 新的生产者是线程安全的,在线程之间共享单个生产者实例,通常单例比多个实例要快. 一个简单的例子,使用producer发送一个有序的key/v ...
- Android GreenDao 深查询 n:m 的关系
在我的应用程序这样设计的关系:和我想选择至少一个用户作为一个朋友的所有聊天. 基本上,我想要执行以下查询:\ SELECT c.* FROM CHAT c, USER u, UserChats uc ...
- UIView动画效果之----翻转.旋转.偏移.翻页.缩放.取反的动画效
翻转的动画 //开始动画 [UIView beginAnimations:@"doflip" context:nil]; //设置时常 [UIView setAnimationDu ...
- 在线matlab网站
网址: http://octave-online.net/ 使用:
- The Singapore NRIC Check Digit
The Singapore NRIC number is made up of 7 digits and a letter behind. This letter is calculated from ...