D. Fish eating fruit

树形dp

题:https://nanti.jisuanke.com/t/41403

题意:求任意俩点之间距离之和模3后的三个结果的总数(原距离之和)

#include<bits/stdc++.h>
using namespace std;
#define pb push_back
typedef long long ll;
const int M=1e4+4;
const int mod=1e9+7;
struct node{
    int v;
    ll w;
};
ll C[M][3],S[M][3],ans[M];
//C[i][j]:表示以i为根,然后路径消耗取模后为j的路径数
//S[i][j]:表示以i为根,路径消耗取模后为j的路径总消耗
vector<node>e[M];;
void dfs(int u,int f,ll pre){
    C[u][0]=C[u][1]=C[u][2]=0;
    S[u][0]=S[u][1]=S[u][2]=0;
    int len=e[u].size();
    for(int i=0;i<e[u].size();i++){
        int v=e[u][i].v;
        if(v==f)
            continue;
        dfs(v,u,e[u][i].w);
        //算跨越跟节点的贡献
        for(int p=0;p<3;p++){
            for(int j=0;j<3;j++)
                for(int k=0;k<3;k++)
                    if(p==(j+k)%3)
                        ans[p]=(ans[p]+S[u][j]*C[v][k]%mod+C[u][j]*S[v][k]%mod)%mod;
        }
        for(int j=0;j<3;j++){
            C[u][j]=(C[u][j]+C[v][j])%mod;
            S[u][j]=(S[u][j]+S[v][j])%mod;
        }

    }

    for(int i=0;i<3;i++)//算以u为跟对答案的贡献,就直接算u的每一个子树的贡献 

        ans[i]=(ans[i]+S[u][i])%mod;
    ll c[3],s[3];
    memset(c,0ll,sizeof(c));
    memset(s,0ll,sizeof(s));
    for(int i=0;i<3;i++){
        int t=(i-pre%3+3)%3;
        c[i]=(c[i]+C[u][t])%mod;
        s[i]=(s[i]+(S[u][t]+C[u][t]*pre%mod)%mod)%mod;
    }
    if(f!=0)
        c[pre%3]=(c[pre%3]+1ll)%mod,s[pre%3]=(s[pre%3]+pre)%mod;
    for(int i=0;i<3;i++)
        C[u][i]=c[i],S[u][i]=s[i];
}
int main(){
    int n;
    while(~scanf("%d",&n)){
        for(int i=0;i<=n;i++)
            e[i].clear();
        memset(S,0,sizeof(S));
        memset(C,0,sizeof(C));
        for(int i=1;i<n;i++){
            int u,v;
            ll w;
            for(int i=0;i<3;i++)
                ans[i]=0ll;
            scanf("%d%d%lld",&u,&v,&w);
            u++,v++;
            e[u].pb(node{v,w});
            e[v].pb(node{u,w});
        }
        dfs(1,0,0);
        printf("%lld %lld %lld\n",ans[0]*2ll%mod,ans[1]*2ll%mod,ans[2]*2ll%mod);

    }
    return 0;;
}

原文地址:https://www.cnblogs.com/starve/p/11521143.html

时间: 2024-07-30 20:33:02

D. Fish eating fruit的相关文章

Fish eating fruit 沈阳网络赛(树形dp)

Fish eating fruit \[ Time Limit: 1000 ms \quad Memory Limit: 262144 kB \] 题意 大体的题意就是给出一棵树,求每一对点之间的距离,然后把该距离存在距离 \(\mod 3\) 的位置,输出总和. 思路 令两个 \(dp\) 数组和两个辅助 \(dp\) 的数组. \(dp1[i][j]\) 表示从 \(i\) 为起点往下到各个点距离 \(\mod 3\) 后为 \(j\) 的距离总和. \(cnt1[i][j]\) 表示以 \

2019 沈阳网络赛 D Fish eating fruit ( 树形DP)

题目传送门 题意:求一颗树中所有点对(a,b)的路径长度,路径长度按照模3之后的值进行分类,最后分别求每一类的和 分析:树形DP \(dp[i][j]\) 表示以 i 为根的子树中,所有子节点到 i 的路径长度模3等于 j 的路径之和 \(c[i][j]\) 表示以 i 为根的子树中,所有子节点到 i 的路径长度模3等于 j 的点数 \(ok[i][j]\) 表示以 i 为根的子树中,是否有子节点到 i 的路径长度模3等于 j 每次只考虑所有经过根 x 的路径,并且路径的一个端点在 x 的一颗子

The Preliminary Contest for ICPC Asia Shenyang 2019

The Preliminary Contest for ICPC Asia Shenyang 2019 Texas hold'em Poker #include <bits/stdc++.h> using namespace std; const int maxn=1e6+10; int num[1000]; int shun(){ for (int i=15;i>=5;i--){ if (num[i]&&num[i-1]&&num[i-2]&&a

高血压_翻译

网页: From Wikipedia, the free encyclopedia http://en.wikipedia.org/wiki/Hypertension 单词 word           count---------------------hypertension   [ha?p?'ten?(?)n]高血压  134 Hypertension is a medical condition in which a person has very high blood pressure

bzoj4393: [Usaco2015 Dec]Fruit Feast

题意: T,A,B.T是上限.A和B可以随意吃但是不能超过T.有一次将吃的东西/2的机会.然后可以继续吃,不能超过T.问最多可以吃多少. =>我们先处理不能/2可以吃到哪些.然后弄个双指针扫一扫就可以了TAT #include<cstdio> #include<cstring> #include<cctype> #include<algorithm> using namespace std; #define rep(i,s,t) for(int i=s

Fruit Feast

Fruit Feast 题目描述 Bessie has broken into Farmer John's house again! She has discovered a pile of lemons and a pile of oranges in the kitchen (effectively an unlimited number of each), and she is determined to eat as much as possible. Bessie has a maxi

Fruit Feast(暴力)(动态规划)

Fruit Feast 时间限制: 1 Sec  内存限制: 64 MB提交: 64  解决: 18[提交][状态][讨论版] 题目描述 Bessie has broken into Farmer John's house again! She has discovered a pile of lemons and a pile of oranges in the kitchen (effectively an unlimited number of each), and she is dete

Fish入门

安装以及配置 Linux和OS X基本都可以通过源来安装,实在不行就下载源码编译,不难的. 安装好第一步是修改OS默认shell: chsh -s /usr/bin/fish 然后就可以直接使用了,就是这么简单.你不需要面对zsh浩如烟海的配置文件,也不需要去github clone一个“Oh My Zsh”. 当然如果你实在想配置,输入fish_config命令会启动web管理界面. 什么?逼格太低,非要手动配置.OK, ~/.config/fish/config.fish这就是fish的配置

[2012山东省第三届ACM大学生程序设计竞赛]——Fruit Ninja II

Fruit Ninja II 题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2416 Time Limit: 5000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 Have you ever played a popular game named "Fruit Ninja"? Fruit Ninja (known as Fruit Ninja