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 ...
随机推荐
- centos7 更换jdk版本
查看java版本 java -version 如果有java版本(如果没有直接看红色虚线以下的) 输入 rpm -qa | grep java会显示以下几条内容: ******* ******** ...
- 再看SpringMVC通过一个DispatcherServlet处理Servlet
初始入口: org.springframework.web.context.ContextLoaderListener org.springframework.web.context.ContextL ...
- 開玩樹莓派(一):安裝Raspbian系統
目錄: 開玩樹莓派(一):安裝Raspbian系統 開玩樹莓派(二):配置IP,實現無顯示器局域網內Putty連接和RDP遠程 開玩樹莓派(三):Python編程 開玩樹莓派(四):GPIO控制和遠程 ...
- 用Excel生成Sql
用Excel生成Sql: 以如图为例:点击一行数据的后面一个单元格,在上面的fx部分输入=,以等号开头证明这是一个公式.在等号的后面写上想要添加的数据,书写规范是这样:'"&A2&a ...
- GCD 使用说明
GCD提供的一些操作队列的方法 名称 说明 dispatch_set_target_queue 将多个队列添加到目标队列中 dispatch_group 将多个队列放入组中,监听所有任务完成状 dis ...
- win7下如何解决协议适配器错误问题
数据库为oracle 11g,在cmd中使用sqlplus命令出现了“协议适配器错误”. 原因分析:oracle相关服务没有启动. 解决办法如下: step1:进入服务页面. 方法一:cmd → se ...
- iis的网站发布
1.打开IIS服务器,添加“新网站”,命名网站的名称.物理路径(存放index.aspx的文件路径).ip地址和端口:2.在已经添加的网站,启用“目录浏览”,“默认文档”设置将要打开的网页 注:(1) ...
- 允许Java App(applet)粘贴方法
修改安全策略文件: "java.policy" JRE6的路径在:"C:\Program Files (x86)\Java\jre6\lib\security" ...
- [习题]输入自己的生日(年/月/日)#2 -- 日历(Calendar)控件的时光跳跃,一次跳回五年、十年前?--TodaysDate属性、VisibleDate属性
原文出處 http://www.dotblogs.com.tw/mis2000lab/archive/2013/06/10/calendar_visibledate_birthday_dropdow ...
- 如何启动Intel VT-x
如何启动Intel VT-x 5 在64bit win7系统下安装了Vmware10,然后安装64位的UbuntuKylin 14.04,想要打开UbuntuKylin,弹出如下对话框: 请问该如何启 ...
