一棵KrusKal重构树,然而我数组开小了,忘记清空一个标记

洛谷传送门

BZOJ传送门 ......好像成权限题了Orz

  回顾我们用KrusKal做生成树的时候,我们将边排序后连通各个连通块,那么边一定是单调的。

所以我们考虑维护一颗最大生成树,然后查询时倍增就好了,复杂度 n * log n

  RE代码,把注释的删了就好了,数组没开够

#include <cstdio>
#include <algorithm>
#include <queue>
#include <cstring>
#include <cctype>
using namespace std;
, M = 1e6 + , inf = 0x7fffffff;
int v[M], to[M], head[N], pos[M], p;
void build(int a, int b, int c) { v[++ p] = b; to[p] = head[a]; head[a] = p; pos[p] = c; }
void link(int a, int b, int c) { build(a, b, c); build(b, a, c); }
int pre[N], far[N], n;
int find(int x) { return pre[x] == x ? x : pre[x] = find(pre[x]); }
struct point {
    int d, f;
    point (int d, int f) : d(d), f(f) {}
    point () {}
    bool operator < (const point &a) const {
        return f > a.f;
    }
};
priority_queue<point> tp;
void dijkstra() {
    ; i <= n; ++ i) far[i] = inf; tp.push(point(, ));
    while( !tp.empty()) {
        int u = tp.top().d; tp.pop();
        for ( int i = head[u]; i; i = to[i]) if( far[v[i]] > far[u] + pos[i]) {
            far[v[i]] = far[u] + pos[i]; tp.push(point(v[i], far[v[i]]));
        }
    }
}
], cnt;
int query(int a, int P) {
    ; i >= ; -- i) if( POS[T[a][i]] > P)
        a = T[a][i];
    return far[a];
}
struct node {
    int u, v, val;
    node ( int u, int v, int val) : u(u), v(v), val(val) {}
    node () {}
    bool operator < (const node &a) const {
        return val > a.val;
    }
}tc[M];
int lastans, Case, m, q, K, s;
inline void G(int &x) {
    x = ; ; ;
    ) + (x << ) + (o & ); x *= f;
}
];
int main() {
    freopen("return1.in", "r", stdin);
    freopen("return.out", "w", stdout);
    G(Case);
    while( Case -- ) {
        G(n), G(m);
        ; i <= n; ++ i) head[i] = ; // p = 0; // 当时好像是因为没加这个RE了.......
        , a, b, c, d; i <= m; ++ i)
            G(a), G(b), G(c), G(d), tc[i] = node(a, b, d), link(a, b, c);
        sort(tc+, tc++m); dijkstra();
        ; i <= n; ++ i) pre[i] = i, POS[i] = inf;
        cnt = n;
        ; i <= m; ++ i) {
            if( find(tc[i].u) == find(tc[i].v)) continue;
            int A = find(tc[i].u), B = find(tc[i].v);
            ++ cnt; POS[cnt] = tc[i].val; far[cnt] = min(far[A], far[B]);
            T[A][] = T[B][] = cnt;
            pre[cnt] = pre[A] = pre[B] = cnt;
        }
        T[cnt][] = T[cnt][] = cnt;
        ; i <= ; ++ i)
            ; k <= cnt; ++ k) T[k][i] = T[T[k][i-]][i-];
        G(q); G(K); G(s);
        cnt = lastans = ;
        , v0, p0; i <= q; ++ i) {
            G(v0); G(p0);
            ) % n + , p0 = (p0 + K * lastans) % (s + );
            lastans = query(v0, p0); int t = lastans;
            , t /= ; while( t);
            '+TP[cnt]); puts("");
        }
    }
    ;
}

woc, 差点忘了这个

[BZOJ 5415] 归程的更多相关文章

  1. [LOJ 2718][UOJ 393][BZOJ 5415][NOI 2018]归程

    [LOJ 2718][UOJ 393][BZOJ 5415][NOI 2018]归程 题意 给定一张无向图, 每条边有一个距离和一个高度. 再给定 \(q\) 组可能在线的询问, 每组询问给定一个点 ...

  2. 【刷题】BZOJ 5415 [Noi2018]归程

    www.lydsy.com/JudgeOnline/upload/noi2018day1.pdf Solution 考试的时候打的可持久化并查集,没调出来QAQ 后面知道了kruskal重构树这个东西 ...

  3. [BZOJ] 5415: [Noi2018]归程

    在做Kruskal求最小生成树时,假设要通过边权\(w\)的边合并子树\(x\)和\(y\),我们新建一个方点,把两个子树接到这个方点上,并将方点的点权赋为\(w\),最终形成的二叉树就是\(Krus ...

  4. BZOJ 5415: [Noi2018]归程(kruskal重构树)

    解题思路 \(NOI2018\)的\(Day1\) \(T1\),当时打网络赛的时候不会做.学了一下\(kruskal\)重构树后发现问题迎刃而解了.根据\(kruskal\)的性质,如果要找从\(u ...

  5. BZOJ 2127: happiness [最小割]

    2127: happiness Time Limit: 51 Sec  Memory Limit: 259 MBSubmit: 1815  Solved: 878[Submit][Status][Di ...

  6. BZOJ 3275: Number

    3275: Number Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 874  Solved: 371[Submit][Status][Discus ...

  7. BZOJ 2879: [Noi2012]美食节

    2879: [Noi2012]美食节 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1834  Solved: 969[Submit][Status] ...

  8. bzoj 4610 Ceiling Functi

    bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...

  9. BZOJ 题目整理

    bzoj 500题纪念 总结一发题目吧,挑几道题整理一下,(方便拖板子) 1039:每条线段与前一条线段之间的长度的比例和夹角不会因平移.旋转.放缩而改变,所以将每条轨迹改为比例和夹角的序列,复制一份 ...

随机推荐

  1. c++之继承与派生

    再来回顾下继承派生的语法. 继承方式显示有三种(public, protected, privatez),隐式默认private.所谓继承方式,是指派生类对基类成员的访问权限控制. 派生类构造函数定义 ...

  2. Swing滚动条重写

    Swing滚动条重写 摘自:https://blog.csdn.net/qq_40064948/article/details/81738191 未验证 Swing滚动条重写 2018年08月16日 ...

  3. 关于pycharm字体大小的调整

    我们平常编写pyhton 可以用sublime eclipse 但是eclipse在后期需要安装很多插件,这很是麻烦,为了避免这种麻烦,我们采用pycharm来编写,但是刚装上的该软件 不建议同学们进 ...

  4. Android onKeyDown、onKeyUp、dispatchKeyEvent的区别

    1. onKeyDown.onKeyUp.dispatchKeyEvent的区别和使用场景 区别: 1.1 onKeyDown.onKeyUp是按键事件的回调接口(冒泡式调用),dispatchKey ...

  5. SVG素材整理(原)

      why SVG? 1.矢量的国际图形标准,以后随着浏览器的发展,相信矢量会更多的出现 2.illustartor等多数矢量绘图软件可以导出为这种格式 so SVG现状   基本介绍:http:// ...

  6. URAL 1356. Something Easier(哥德巴赫猜想)

    题目链接 题意 : 给你一个数n,让你找出几个素数,使其相加为n,输出这些素数. 思路 : 哥德巴赫猜想 : 任何一个大于 6的偶数都可以表示成两个素数之和. 任何一个大于9的奇数都可以表示成三个素数 ...

  7. JQuery解决事件动画重复问题

    开发项目时,经常要写动画效果,有时候会遇到动画重复问题,例如:当鼠标移动到某个元素上时,执行某个动画,当我鼠标多次移动到该元素时,该动画就要连续执行,那么怎么去解决呢? 话不多说,直接添代码,简单明了 ...

  8. Java 核心类库之反射机制

    1:什么是反射机制? 2:反射机制它可以做什么呢? 3:反射机制对应的API又是什么? 1):通过反射机制来获取一个对象的全限定名称(完整包名),和类名: 2):实例化Class对象 3):获取对象的 ...

  9. jquery操作select(取值,设置选中) 基础

    每一次操作select的时候,总是要出来翻一下资料,不如自己总结一下,以后就翻这里了. 比如<select class="selector"></select&g ...

  10. 完美解决bootstrap模态框允许拖动后拖出边界的问题

    使用bootstrap3版本 在网上看了很多方法,我觉得jquery-ui的实现方法是最简单有效的,具体实现方法 1.下载并引入jquery-ui插件 2.全局添加模态框允许拖动事件 $(docume ...