首页 > 其他分享 >NC14419 线路规划

NC14419 线路规划

时间:2023-06-23 12:55:04浏览次数:29  
标签:上司 int 成员 dsu 线路 fa NC14419 规划 find

题目链接

题目

题目描述

Q国的监察院是一个神秘的组织。
这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人。
监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只听从其上直接司的命令。其中1号成员是监察院的院长,这个庞然大物的主人。
由于时代的进步,监察院议会决定升级组织的旧式通信器,安装最新的反侦测通信器。
他们拿出了M组线路方案,其中第i组线路方案可以用一个四元组(x[i]、y[i]、k[i]、w[i])描述,表示第x[i]号成员可以安装与y[i]号成员的直接通信线路,费用为w[i];x[i]号成员的上司可以安装与y[i]号成员的上司的直接通信线路,费用为w[i];x[i]号成员的上司的上司可以安装与y[i]号成员的上司的上司的直接通信线路,费用为w[i]; …… ;x[i]号成员的k[i] - 1级上司可以安装与y[i]号成员的k[i] - 1级上司的直接通信线路,费用为w[i]。(这k[i]条线路的费用独立计算)
如果一个集合内部的成员两两之间都可以通过直接或间接的通信线路进行通信,那么这个集合的所有成员可以成立一个特别行动组。
监察院想成立一个成员最多的特别行动组,同时他们想让安装线路的费用之和最小,
所以他们找到了Q国的天命者——你,请你帮助他们规划出最优的线路。

输入描述

第一行为2个正整数N、M。
第二行为N - 1个正整数L[i],第i个正整数表示第i+1个成员的直接上司L[i]。
接下来M行每行四个正整数x[i],y[i],k[i],w[i]。

输出描述

仅一行,为特别行动组成员人数的最大值和在此前提下安装线路的最小费用之和。

示例1

输入

5 3
1 1 2 2
5 4 3 10
1 3 1 5
2 4 2 3

输出

5 21

说明

设(u、v、w)表示一条u到v,费用为w的线路。
则一共有(5、4、10)、(2、2、10)、(1、1、10)、(1、3、5)、(2、4、3)、(1、2、3)共6条线路。
选择第1、4、5、6条线路,可以成立特别行动组{1、2、3、4、5},费用之和为21

备注

对于100%的数据:
1 ≤ N、M ≤ 252501
1≤x[i],y[i],k[i]≤N,1≤L[i]≤i - 1,保证x[i]、y[i]号成员均至少有k[i]个上司,\(1≤w[i]≤10^9\) 。

题解

知识点:倍增,并查集。

这题的思路非常妙,是一个按批处理的最小生成树。由于给的边都是一批一批的,一个一个处理一定超时。但是,一批边可以通过边权、起边的两个端点、上升边数唯一确定,我们可以利用这个性质一批一批处理,就能省很多时间。

具体地说,可以设 \(e_i\) 表示有 \(2^i\) 条边的若干批边,随后我们将给定的每批边细分成 \(2\) 的幂次的若干批。例如一批边有 \(11\) 条,则可以分为 \(8,2,1\) 条边的批次,将其分别放在 \(e_3,e_1,e_0\) 即可。需要注意的是,起边端点也需要随之改动,因此还需要预处理向上跳跃的倍增。

然后,按边数从大到小遍历 \(e_i\) ,对边数相同的若干批边,采用类似最小生成树的做法,筛选留下的批次。直到处理完 \(e_0\) ,留在 \(e_0\) 的边就是我们需要的,即完成了按批处理的最小生成树。

其中,对于同一边数的若干批边,我们需要选出一些批次,使得连通性不变,但边权最小,类似最小生成树。因此按批次边的权重从小到大排列,用并查集维护连通性,类似kruskal算法。最后,留下的若干批次,我们需要继续细分,排除更多的边。例如, \(e_3\) 的处理完,留下的都是 \(2^3\) 边数的批次,需要细分成 \(2^2\) 存入 \(e_2\) 继续筛选。同样地,需要注意起边端点问题。

最终我们需要统计各个最小生成树的点数和边权和,选出连通点的数量最多的情况下边权和最小的答案。

时间复杂度 \(O(\log k(n + m(\log m +\log n)) + n\log n)\)

空间复杂度 \(O(m \log k + n \log n)\)

代码

#include <bits/stdc++.h>
using namespace std;
using ll = long long;

struct Graph {
    struct edge {
        int v, nxt;
    };
    int idx;
    vector<int> h;
    vector<edge> e;

    Graph(int n = 0, int m = 0) { init(n, m); }

    void init(int n, int m) {
        idx = 0;
        h.assign(n + 1, 0);
        e.assign(m + 1, {});
    }

    void add(int u, int v) {
        e[++idx] = { v,h[u] };
        h[u] = idx;
    }
};

struct DSU {
    vector<int> fa;

    DSU(int n = 0) { init(n); }

    void init(int n) {
        fa.assign(n + 1, 0);
        iota(fa.begin(), fa.end(), 0);
    }

    int find(int x) { return fa[x] == x ? x : fa[x] = find(fa[x]); }

    bool same(int x, int y) { return find(x) == find(y); }

    void merge(int x, int y) { fa[find(x)] = find(y); }
};

const int N = 300000;
Graph g;

int f[27][N];
void dfs(int u, int fa) {
    f[0][u] = fa;
    for (int i = 1;i <= 20;i++)
        f[i][u] = f[i - 1][f[i - 1][u]];
    for (int i = g.h[u];i;i = g.e[i].nxt) {
        int v = g.e[i].v;
        dfs(v, u);
    }
}

struct node {
    int u, v, w;
    friend bool operator<(const node &a, const node &b) { return a.w < b.w; }
};
vector<node> e[27];


int main() {
    std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    int n, m;
    cin >> n >> m;
    g.init(n, n);
    for (int i = 2;i <= n;i++) {
        int u;
        cin >> u;
        g.add(u, i);
    }

    dfs(1, 0);

    for (int i = 1;i <= m;i++) {
        int u, v, k, w;
        cin >> u >> v >> k >> w;
        for (int i = 20;i >= 0;i--) {
            if (k & (1 << i)) {
                e[i].push_back({ u,v,w });
                u = f[i][u];
                v = f[i][v];
            }
        }
    }
    for (int i = 20;i >= 1;i--) {
        sort(e[i].begin(), e[i].end());
        DSU dsu(n);
        for (auto [u, v, w] : e[i]) {
            if (dsu.same(u, v)) continue;
            dsu.merge(u, v);
            e[i - 1].push_back({ u,v,w });
            e[i - 1].push_back({ f[i - 1][u],f[i - 1][v],w });
        }
    }
    sort(e[0].begin(), e[0].end());
    DSU dsu(n);
    vector<pair<int, ll>> node_ans(n + 1);
    for (auto [u, v, w] : e[0]) {
        if (dsu.same(u, v)) continue;
        dsu.merge(u, v);
        node_ans[dsu.find(u)].first++;
        node_ans[dsu.find(u)].second += w;
    }
    for (int i = 1;i <= n;i++) {
        if (dsu.find(i) != i) {
            node_ans[dsu.find(i)].first += node_ans[i].first;
            node_ans[dsu.find(i)].second += node_ans[i].second;
        }
    }
    vector<pair<int, ll>> ans;
    for (int i = 1;i <= n;i++) if (dsu.find(i) == i) ans.push_back(node_ans[i]);
    sort(ans.begin(), ans.end(), [&](pair<int, ll> a, pair<int, ll> b) {return a.first == b.first ? a.second < b.second : a.first>b.first;});
    cout << ans[0].first + 1 << ' ' << ans[0].second << '\n';
    return 0;
}

标签:上司,int,成员,dsu,线路,fa,NC14419,规划,find
From: https://www.cnblogs.com/BlankYang/p/17499018.html

相关文章

  • 网络计划技术——供应链网络规划案例
    供应链网络是由供应商、制造商、分销商和零售商等组成的一个综合体系,用于管理和协调产品的流动和交付。它涵盖了从原材料采购到产品销售的整个过程,包括物流、库存管理、信息流等方面。一个高效的供应链网络能够实现资源的优化配置、降低成本、提高交付速度和客户满意度,从而增强企......
  • 代码随想录算法训练营第43天 | ● 1049. 最后一块石头的重量 II ● 494. 目标和
     第九章 动态规划 part05●  1049. 最后一块石头的重量 II ●  494. 目标和 ●  474.一和零    详细布置   1049. 最后一块石头的重量 II  本题就和 昨天的 416. 分割等和子集 很像了,可以尝试先自己思考做一做。 视频讲解:https://www......
  • 如何规划令人流连忘返的网站?
    信息架构的重要性毋庸置疑,就像盖房子要有建筑图纸,建网站同样要有设计蓝图。但是人们常常会不甚明了,信息架构到底是什么?怎样才能得到合适的信息架构?读完《锦绣蓝图:怎样规划令人流连忘返的网站,你会感受到这个原本在我们眼中很抽象很朦胧的概念实际上一直都真真切切地在......
  • 信捷PLC程序,八轴程序,有伺服也有步进,内部有伺服和步进计算公式换算,模块化编程框架,包含
    信捷PLC程序,八轴程序,有伺服也有步进,内部有伺服和步进计算公式换算,模块化编程框架,包含各功能区规划,伺服步进电机DOG+JOG,气缸手动,公式计算数据处理,报警功能区,自动步进S调用等。研究透彻应用此思维,完全能应用上手中大型各日系主流系统,如日本三菱,松下,欧姆龙,基恩士,国内主流信捷,汇川,台......
  • 强化学习从基础到进阶-常见问题和面试必知必答[2]:马尔科夫决策、贝尔曼方程、动态规划
    强化学习从基础到进阶-常见问题和面试必知必答[2]:马尔科夫决策、贝尔曼方程、动态规划、策略价值迭代1.马尔科夫决策核心词汇马尔可夫性质(Markovproperty,MP):如果某一个过程未来的状态与过去的状态无关,只由现在的状态决定,那么其具有马尔可夫性质。换句话说,一个状态的下一个状态......
  • 强化学习从基础到进阶-常见问题和面试必知必答[2]:马尔科夫决策、贝尔曼方程、动态规划
    强化学习从基础到进阶-常见问题和面试必知必答[2]:马尔科夫决策、贝尔曼方程、动态规划、策略价值迭代1.马尔科夫决策核心词汇马尔可夫性质(Markovproperty,MP):如果某一个过程未来的状态与过去的状态无关,只由现在的状态决定,那么其具有马尔可夫性质。换句话说,一个状态的下一个状态......
  • 听说有人不做职业规划?
    本文首发自公粽hao「林行学长」,欢迎来撩,免费领取20个求职工具资源包。了解校招、分享校招知识的学长来了!试想一下,你和面试官侃侃而谈关于岗位关于经历,接着,面试官问你:”你的未来规划是什么?“这个问题是面试必问环节之一你会怎么回答?问这个问题,面试官想考察什么?考察你对自我的认知、......
  • 关于数据治理的读书笔记 - 数据治理路线图规划
    数据治理成熟度评估为企业提供了一个数据治理的切入点,通过发现企业数据治理中存在的问题,找到目前和业界领先企业的差距,绘制出符合企业现状和需求的数据治理路线图。路线图是指描述技术变化步骤或技术相关环节之间逻辑关系的简洁的图形、表格、文字等形式。数据治理路线图则是对企业......
  • 同类型,类背包动态规划,选地dp
    弱化版:黑虎阿福: 题目描述 阿福是一名经验丰富的大盗。趁着月黑风高,阿福打算今晚洗劫一条街上的店铺。这条街上一共有NNN家店铺,每家店中都有一些现金。阿福事先调查得知,只有当他同时洗劫了两家相邻的店铺时,街上的报警系统才会启动,然后警察就会蜂拥而至。作为一向谨慎......
  • BGP线路是什么意思?服务器单线、双线、三线以及BGP线路有什么区别?
    随着互联网规模的不断扩大,服务器租赁托管也越来越流行,服务器租赁托管线路有:单线、双线、三线和BGP线路,那么它们有什么区别和联系呢?首先,我们理解它们的含义,再比较它们的优缺点单线:一般指电信单线路或联通单线路或移动单线路(单网卡单IP)。单线服务器是指IDC机房要么是联通线路接入,要......