这道题呢,

首先按照关键字a排序,然后不断地加边,用lct维护这个过程

具体实现: 先按照关键字a排序,枚举每一条边,判断两点是否已经联通(kruskal 部分)如果联通,就在两点路径间寻找最大的b, 和这条边的b值相比较,如果更大一些,就切断u,v之间的路径, 并连上这条边;

如果不联通,就让它联通(好随意啊= =

最后寻找路径之间最大的b + 当前的a,和原来的答案相比较。

剩下的用lct维护

注意联通的方式是把把边看做点, 然后连接(所以加上n)   ->link(u, i + n);  link(v, i + n);

(由于我一直不理解怎么保证当前的a一定在路径上,所以这是自己yy的证明(可能有很大的bug,勿喷):当前的a如果不在(1,n)路径之中,但(1,n)已联通,那么最优值在之前已经被计算过,否则由于a是递增的,那么此时的a就是路径中最大的a)

下面是代码

 /**************************************************************
    Problem: 3669
    User: cminus
    Language: C++
    Result: Accepted
    Time:5104 ms
    Memory:6128 kb
****************************************************************/
 
#include <cstdio>
#include <algorithm>
using namespace std;
#define l(x) ch[x][0]
#define r(x) ch[x][1]
#define kd(x) (r(fa[x]) == x)
#define setc(f, c, k)   (ch[fa[c] = f][k] = c)
#define isRoot(x)   (r(fa[x]) != x && l(fa[x]) != x)
const int N = ;
 
struct Edge{
    int u, v, a, b;
    inline void init(){
        scanf("%d %d %d %d", &u, &v, &a, &b);
    }
    inline bool operator <(const Edge &rhs)const{
        return a < rhs.a;
    }
}e[];
int fa[N], ch[N][], rev[N], val[N], maxp[N], f[];
int INF = 0x7f7f7f7f;
 
inline void update(int x) {
    maxp[x] = x;
    if (val[maxp[x]] < val[maxp[l(x)]])  maxp[x] = maxp[l(x)];
    if (val[maxp[x]] < val[maxp[r(x)]])  maxp[x] = maxp[r(x)];
}
 
inline void push(int x) {
    if (rev[x] and x){
        rev[x] = ;
        if (l(x))   rev[l(x)] ^= , swap(l(l(x)), r(l(x)));
        if (r(x))   rev[r(x)] ^= , swap(l(r(x)), r(r(x)));
    }
}
 
inline void pushDown(int x) {
    if (! isRoot(x))    pushDown(fa[x]);
    push(x);
}
 
inline void rotate(int x) {
    int y = fa[x], t = kd(x);
    setc(y, ch[x][t^], t);
    if (isRoot(y)) fa[x] = fa[y];
    else setc(fa[y], x, kd(y));
    setc(x, y, t^);
    update(y); update(x);
}
 
inline void splay(int x){
    pushDown(x);
    while(! isRoot(x)){
        if (! isRoot(fa[x]))
            if (kd(x) == kd(fa[x]))     rotate(fa[x]);
            else    rotate(x); rotate(x);
    }
}
 
inline void access(int x){
    int t = ;
    while(x) {
        splay(x);
        r(x) = t; update(x);
        t = x; x = fa[x];
    }
}
 
inline void makeRoot(int x){
    access(x); splay(x);
    rev[x] ^= ;  swap(l(x), r(x));
}
 
inline void link(int u, int v) {    makeRoot(u);  fa[u] = v; }
 
inline void cut(int u, int v){
    makeRoot(u);
    access(v); splay(v);
    fa[u] = l(v) = ;
}
 
inline int query(int u, int v){
    makeRoot(u);
    access(v); splay(v);
    return maxp[v];
}
 
int find(int x) { return f[x] == x ? x : f[x] = find(f[x]); }
 
int main(){
    int n, m;
    scanf("%d %d", &n, &m);
    int ans = INF;
    for (int i = ; i <= m; i++) e[i].init();
    for (int i = ; i <= n; i++) f[i] = i;
    sort(e + , e + m + );
    for (int i = ; i <= m; i++){
        int u = e[i].u, v = e[i].v, rt1 = find(u), rt2 = find(v);
        val[i + n] = e[i].b; maxp[i + n] = i + n;
        if (rt1 == rt2){
            int p = query(u, v);
            if (val[p] > e[i].b)   cut(u, p), cut(v, p);
            else   continue;   
        }
        else f[rt1] = rt2;
        link(u, i + n); link(v, i + n);
        if (find() == find(n)) ans = min(ans, val[query(, n)] + e[i].a);
    }
    printf("%d\n", ans == INF ? - : ans);
    return ;
}

bzoj 3669: [Noi2014]魔法森林 (LCT & kruskal)的更多相关文章

  1. BZOJ 3669: [Noi2014]魔法森林 [LCT Kruskal | SPFA]

    题目描述 为了得到书法大家的真传,小 E 同学下定决心去拜访住在魔法森林中的隐 士.魔法森林可以被看成一个包含 n 个节点 m 条边的无向图,节点标号为 1,2,3,…,n,边标号为 1,2,3,…, ...

  2. BZOJ 3669: [Noi2014]魔法森林( LCT )

    排序搞掉一维, 然后就用LCT维护加边MST. O(NlogN) ------------------------------------------------------------------- ...

  3. bzoj 3669: [Noi2014]魔法森林 (LCT)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3669 题面: 3669: [Noi2014]魔法森林 Time Limit: 30 Sec  ...

  4. bzoj 3669: [Noi2014] 魔法森林 LCT版

    Description 为了得到书法大家的真传,小E同学下定决心去拜访住在魔法森林中的隐士.魔法森林可以被看成一个包含个N节点M条边的无向图,节点标号为1..N,边标号为1..M.初始时小E同学在号节 ...

  5. BZOJ 3669: [Noi2014]魔法森林(lct+最小生成树)

    传送门 解题思路 \(lct\)维护最小生成树.我们首先按照\(a\)排序,然后每次加入一条边,在图中维护一棵最小生成树.用并查集判断一下\(1\)与\(n\)是否联通,如果联通的话就尝试更新答案. ...

  6. bzoj 3669: [Noi2014]魔法森林

    bzoj 3669: [Noi2014]魔法森林 Description 为了得到书法大家的真传,小E同学下定决心去拜访住在魔法森林中的隐士.魔法森林可以被看成一个包含个N节点M条边的无向图,节点标号 ...

  7. bzoj 3669: [Noi2014]魔法森林 动态树

    3669: [Noi2014]魔法森林 Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 363  Solved: 202[Submit][Status] ...

  8. bzoj 3669: [Noi2014]魔法森林 -- 动点spfa

    3669: [Noi2014]魔法森林 Time Limit: 30 Sec  Memory Limit: 512 MB 动点spfa Description 为了得到书法大家的真传,小E同学下定决心 ...

  9. [BZOJ 3669] [Noi2014] 魔法森林 【LCT】

    题目链接:BZOJ - 3669 题目分析 如果确定了带 x 只精灵A,那么我们就是要找一条 1 到 n 的路径,满足只经过 Ai <= x 的边,而且要使经过的边中最大的 Bi 尽量小. 其实 ...

  10. bzoj 3669: [Noi2014]魔法森林(并查集+LCT)

    Description 为了得到书法大家的真传,小E同学下定决心去拜访住在魔法森林中的隐士.魔法森林可以被看成一个包含个N节点M条边的无向图,节点标号为1..N,边标号为1..M.初始时小E同学在号节 ...

随机推荐

  1. css揭秘 一

    当某些值相互依赖是,应该把它们的相互关系用代码表达出来 font-size: 20px; line-height: 1.5; // 行高是字体的1.5倍 当改变某个参数时候,做到只改尽量少的地方,最好 ...

  2. Pair类模板

    >Pair的实现是一个结构体而不是一个类< 1.标准头文件 #include<utility> 似乎无需引入该文件,在std命名空间内也有pair类型 2.格式为:templa ...

  3. 谷歌 AI 负责人谈2020 年机器学习趋势:多任务和多模态会有大突破

    ​在上周加拿大温哥华举行的NeurIPS会议上,机器学习成为了中心议题. 来自世界范围内约1.3万名研究人员集中探讨了神经科学.如何解释神经网络输出以及人工智能如何帮助解决现实世界中的重大问题等焦点话 ...

  4. zedboard通过BRAM实现PS和PL的简单通信

    使用Block Memory进行PS和PL的数据交互或者数据共享,通过zynq PS端的Master GP0端口向BRAM写数据,然后再通过PS端的Mater GP1把数据读出来,将结果打印输出到串口 ...

  5. Windows 性能监视器的基本指标(CPU,内存,硬盘参数)

    转载:http://kms.lenovots.com/kb/article.php?id=7045 Windows 性能监视器的基本指标(CPU,内存,硬盘参数) 作为一个系统工程师来说,要看懂监控的 ...

  6. Unable to open debugger port (127.0.0.1:13249): java.net.BindException "Address already in use: JVM_Bind"

    这个问题比较简单一点,Tomcat的端口被占用了,我使用的是IDEA里的一个热部署插件JReble,更新了IDEA之后就发现端口被占用了,可能我电脑没有重启过吧, 一直被占用着,所以解决方法就是更换一 ...

  7. 第四十九篇 入门机器学习——数据归一化(Feature Scaling)

    No.1. 数据归一化的目的 数据归一化的目的,就是将数据的所有特征都映射到同一尺度上,这样可以避免由于量纲的不同使数据的某些特征形成主导作用.   No.2. 数据归一化的方法 数据归一化的方法主要 ...

  8. 【基础问题】String 类型为什么是final类型

    关于为什么此类问题,都能列出12345...种种原因 已创建具体的值不可修改,故本身就是线程安全的,放到多线程中也不会担心被修改,支持在多线程中共享自身 . 因为字符串是不可变的,所以在它创建的时候H ...

  9. 已经安装了 AccessDatabaseEngine.exe,还是报错

    标题: SQL Server 导入和导出向导 ------------------------------ 操作无法完成. ------------------------------ 其他信息: 未 ...

  10. 记录 Docker 的学习过程 (网络篇之跨主机互通)

    下面从node3上操作node3# docker run -d -p 8500:8500 --name consul progrium/consul -server -bootstrap node3# ...