URAL 1018 Binary Apple Tree

URAL 1018 Binary Apple Tree

    可以用f[i][j]表示递推到第i个节点时保留j个树枝的最优解,决策的时候要么只从某个子树中选取,要么就同时从两个子树中选取,而且如果选择了某个子树中的树枝,那么就必须选择和这个子树相连接的树枝。

#include<stdio.h>
#include<string.h>
#define MAXD 110
#define MAXM 210
int N, Q, e, first[MAXD], next[MAXM], v[MAXM], w[MAXM], f[MAXD][MAXD];
void add(int x, int y, int z)
{
    v[e] = y, w[e] = z;
    next[e] = first[x], first[x] = e ++;
}
void init()
{
    int i, j, k, x, y, z;
    memset(first, -1, sizeof(first));
    e = 0;
    for(i = 1; i < N; i ++)
    {
        scanf("%d%d%d", &x, &y, &z);
        add(x, y, z);
        add(y, x, z);    
    }
}
void dfs(int cur, int fa)
{
    int i, j, n = 0, g[2], num[2];
    for(i = first[cur]; i != -1; i = next[i])
        if(v[i] != fa)
        {
            g[n] = v[i], num[n] = w[i];
            ++ n;
            dfs(v[i], cur);
        }
    if(n == 1)
    {
        for(i = 1; i <= Q; i ++)
            f[cur][i] = f[g[0]][i - 1] + num[0];    
    }
    else if(n == 2)
    {
        f[cur][1] = num[0] > num[1] ? num[0] : num[1];
        for(i = 2; i <= Q; i ++)
        {
            for(j = 0; j < 2; j ++)
                if(f[g[j]][i - 1] + num[j] > f[cur][i])
                    f[cur][i] = f[g[j]][i - 1] + num[j];    
            for(j = 0; j <= i - 2; j ++)
                if(f[g[0]][j] + num[0] + f[g[1]][i - 2 - j] + num[1] > f[cur][i])
                    f[cur][i] = f[g[0]][j] + num[0] + f[g[1]][i - 2 - j] + num[1];
        }
    }
}
void solve()
{
    memset(f, 0, sizeof(f));
    dfs(1, -1);
    printf("%d\n", f[1][Q]);    
}
int main()
{
    while(scanf("%d%d", &N, &Q) == 2)
    {
        init();    
        solve();
    }
    return 0;    
}

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/110415.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • JRebel热部署

    JRebel热部署

    2021年7月11日
    78
  • HttpCanary_django request对象

    HttpCanary_django request对象HttpResponse对象Django服务器接收到客户端发送过来的请求后,会将提交上来的这些数据封装成一个HttpRequest对象传给视图函数。那么视图函数在处理完相关的逻辑后,也需要返回一个响

    2022年7月29日
    7
  • unittest自动化测试框架_unittest批量加载用例

    unittest自动化测试框架_unittest批量加载用例目录一、unittest简介二、基本概念三、unittest基础使用四、unitteest提供的各种断言方式五、unittest测试用例跳过执行六、总结一、unittest简介测试框架-unittest,相当于是一个python版的junit。python里面的单元测试框架除了unittest,还有一个pytest框架,这个实际上用的比较少,后面有空再继续介绍和分享。unittest单元测试框架不仅可以适用于单元测试,还可以适用WEB自动化测试用例的

    2022年10月14日
    2
  • python基础(7)内置函数divmod用法

    python基础(7)内置函数divmod用法前言我们都知道,python中//代表整数运算中的取整,%代表整数运算中的取余,那么有什么函数可以同时取到整数和余数吗?答案是有的,使用python内置函数divmoddivmod首先看一下源

    2022年8月7日
    5
  • react拖拽排序组件_uniapp拖拽生成器

    react拖拽排序组件_uniapp拖拽生成器移动端的拖拽排序在react中实现 了解一下

    2022年4月20日
    217
  • java StringTokenizer

    java StringTokenizerStringTokenizer是一个用来分隔String的应用类,相当于VB的split函数。1.构造函数publicStringTokenizer(Stringstr)publicStringTokenizer(Stringstr,Stringdelim)publicStringTokenizer(Stringstr,Stringdelim,boolean

    2022年8月11日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号