加载中...

供应链总销售额

https://www.acwing.com/problem/content/description/1567/

思路:
这题可以不用记忆化搜索写,也不是很烦,在这儿记忆化搜索主要是用来解决求树的深度用的。

#include <iostream>
#include <cstring>
#include <algorithm>
#include <cmath>

using namespace std;

const int N = 100010;

int n;
double P, R;
int p[N], f[N], c[N];

int dfs(int u)
{
    if (f[u] != -1) return f[u];

    if (p[u] == -1) return f[u] = 0;
    return f[u] = dfs(p[u]) + 1;
}

int main()
{
    cin >> n >> P >> R;

    memset(p, -1, sizeof p);
    for (int i = 0; i < n; i ++ )
    {
        int k;
        cin >> k;
        for (int j = 0; j < k; j ++ )
        {
            int son;
            cin >> son;
            p[son] = i;
        }

        if (!k) cin >> c[i];
    }

    memset(f, -1, sizeof f);

    double res = 0;
    for (int i = 0; i < n; i ++ )
        if (c[i])
            res += c[i] * P * pow(1 + R / 100, dfs(i));

    printf("%.1lf\n", res);

    return 0;
}

posted @ 2022-08-19 20:44  英雄不问出处c  阅读(22)  评论(0编辑  收藏  举报