• [Swift]LCP 5. 发 LeetCoin


    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
    ➤微信公众号:山青咏芝(let_us_code)
    ➤博主域名:https://www.zengqiang.org
    ➤GitHub地址:https://github.com/strengthen/LeetCode
    ➤原文地址:https://www.cnblogs.com/strengthen/p/12151724.html
    ➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
    ➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★

    该刷题团队的管理模式可以用一棵树表示:

    团队只有一个负责人,编号为1。除了该负责人外,每个人有且仅有一个领导(负责人没有领导);
    不存在循环管理的情况,如A管理B,B管理C,C管理A。
     

    力扣想进行的操作有以下三种:

    给团队的一个成员(也可以是负责人)发一定数量的LeetCoin;
    给团队的一个成员(也可以是负责人),以及他/她管理的所有人(即他/她的下属、他/她下属的下属,……),发一定数量的LeetCoin;
    查询某一个成员(也可以是负责人),以及他/她管理的所有人被发到的LeetCoin之和。
     

    输入:

    N表示团队成员的个数(编号为1~N,负责人为1);
    leadership是大小为(N - 1) * 2的二维数组,其中每个元素[a, b]代表b是a的下属;
    operations是一个长度为Q的二维数组,代表以时间排序的操作,格式如下:
    operations[i][0] = 1: 代表第一种操作,operations[i][1]代表成员的编号,operations[i][2]代表LeetCoin的数量;
    operations[i][0] = 2: 代表第二种操作,operations[i][1]代表成员的编号,operations[i][2]代表LeetCoin的数量;
    operations[i][0] = 3: 代表第三种操作,operations[i][1]代表成员的编号;
    输出:

    返回一个数组,数组里是每次查询的返回值(发LeetCoin的操作不需要任何返回值)。由于发的LeetCoin很多,请把每次查询的结果模1e9+7 (1000000007)。

    示例 1:

    输入:N = 6, leadership = [[1, 2], [1, 6], [2, 3], [2, 5], [1, 4]], operations = [[1, 1, 500], [2, 2, 50], [3, 1], [2, 6, 15], [3, 1]]
    输出:[650, 665]
    解释:团队的管理关系见下图。
    第一次查询时,每个成员得到的LeetCoin的数量分别为(按编号顺序):500, 50, 50, 0, 50, 0;
    第二次查询时,每个成员得到的LeetCoin的数量分别为(按编号顺序):500, 50, 50, 0, 50, 15.

    限制:

    1 <= N <= 50000
    1 <= Q <= 50000
    operations[i][0] != 3 时,1 <= operations[i][2] <= 5000

  • 相关阅读:
    做题记录
    关于有向图强连通分量的一点想法
    浅谈二分图匹配(未完)
    水题狂欢赛 (爬楼梯赛)题解(偏向自我反省)
    浅谈迭代加深(iddfs)
    浅谈单调队列优化
    [cqbzoj#10644]鱼肉炸弹题解
    树形背包[2/ 50] luogu [P1273]
    树形背包[1/ 50] luogu [P2015] (超级板)
    (树状数组)区间修改,区间查询
  • 原文地址:https://www.cnblogs.com/strengthen/p/12151724.html
Copyright © 2020-2023  润新知