传送门

前置技能,克鲁斯卡尔重构树

我们按道路的高度建一个最大生成树,然后建好克鲁斯卡尔重构树

那么我们需要知道一颗子树内到1点距离最近是多少(除此之外到子树内任何一个点都不需要代价)

可以一开始直接跑一个dijkstra(关于SPFA,他死了)

然后一遍树形dp就可以了

 //minamoto
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<queue>
using namespace std;
#define getc() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++)
char buf[<<],*p1=buf,*p2=buf;
template<class T>inline bool cmin(T&a,const T&b){return a>b?a=b,:;}
inline int read(){
#define num ch-'0'
char ch;bool flag=;int res;
while(!isdigit(ch=getc()))
(ch=='-')&&(flag=true);
for(res=num;isdigit(ch=getc());res=res*+num);
(flag)&&(res=-res);
#undef num
return res;
}
char sr[<<],z[];int C=-,Z;
inline void Ot(){fwrite(sr,,C+,stdout),C=-;}
inline void print(int x){
if(C><<)Ot();if(x<)sr[++C]=,x=-x;
while(z[++Z]=x%+,x/=);
while(sr[++C]=z[Z],--Z);sr[++C]='\n';
}
const int N=;
struct EE{
int u,v,h;
EE(){}
EE(int u,int v,int h):u(u),v(v),h(h){}
inline bool operator <(const EE &b)const
{return h>b.h;}
}E[N];
struct node{
int u,dis;
node(){}
node(int u,int dis):u(u),dis(dis){}
inline bool operator <(const node &b)const
{return dis>b.dis;}
};
int head[N],Next[N],ver[N],edge[N],tot;
int hc[N],nc[N],vc[N],tc;
int val[N],f[N][],fa[N],dis[N],vis[N],mn[N],bin[];
int n,m,ans,k;
priority_queue<node> q;
inline void clear(){
memset(head,,sizeof(head)),tot=;
memset(hc,,sizeof(hc)),tc=;
memset(mn,0x3f,sizeof(mn));
memset(f,,sizeof(f));
}
inline void add(int u,int v,int e){
ver[++tot]=v,Next[tot]=head[u],head[u]=tot,edge[tot]=e;
}
inline void addc(int u,int v){
vc[++tc]=v,nc[tc]=hc[u],hc[u]=tc;
}
inline int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
inline void mission(int u){
for(int i=;bin[i]<=n;++i)
f[u][i]=f[f[u][i-]][i-];
}
void dijkstra(int s=){
memset(vis,,sizeof(vis));
memset(dis,0x3f,sizeof(dis));
q.push(node(s,)),dis[s]=;
while(!q.empty()){
int u=q.top().u;q.pop();
if(vis[u]) continue;
vis[u]=;
for(int i=head[u];i;i=Next[i]){
int v=ver[i];
if(cmin(dis[v],dis[u]+edge[i])) q.push(node(v,dis[v]));
}
}
memcpy(mn+,dis+,sizeof(int)*(n));
}
void dfs(int u){
mission(u);
for(int i=hc[u];i;i=nc[i]){
int v=vc[i];
dfs(v),cmin(mn[u],mn[v]);
}
}
inline int query(int u,int x){
for(int i=;~i;--i)
if(f[u][i]&&val[f[u][i]]>x) u=f[u][i];
return mn[u];
}
void kruskal(){
int cnt=n;
for(int i=;i<=(n<<);++i) fa[i]=i;
sort(E+,E++m);
for(int i=;i<=m;++i){
int u=find(E[i].u),v=find(E[i].v);
if(u!=v){
val[++cnt]=E[i].h;
f[u][]=f[v][]=cnt,fa[u]=fa[v]=cnt;
addc(cnt,u),addc(cnt,v);
if(cnt-n==n-) break;
}
}
dfs(cnt);
}
int main(){
// freopen("testdata.in","r",stdin);
int T=read();
bin[]=;for(int i=;i<=;++i) bin[i]=bin[i-]<<;
while(T--){
n=read(),m=read(),ans=;
clear();
for(int i=,u,v,e,h;i<=m;++i){
u=read(),v=read(),e=read(),h=read(),E[i]=EE(u,v,h);
add(u,v,e),add(v,u,e);
}
dijkstra();
kruskal();
int q=read(),k=read(),s=read();
while(q--){
int u=(k*ans+read()-)%n+,v=(k*ans+read())%(s+);
print(ans=query(u,v));
}
}
Ot();
return ;
}

洛谷P4768 [NOI2018]归程(克鲁斯卡尔重构树+最短路)的更多相关文章

  1. 洛谷 P1967 货车运输(克鲁斯卡尔重构树)

    题目描述 AAA国有nn n座城市,编号从 11 1到n nn,城市之间有 mmm 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 qqq 辆货车在运输货物, 司机们想知道每辆车在不超过车 ...

  2. P4768 [NOI2018]归程(kruskal 重构树)

    洛谷P4768 [NOI2018]归程 LOJ#2718.「NOI2018」归程 用到 kruskal 重构树,所以先说这是个啥 显然,这和 kruskal 算法有关系 (废话 这个重构树是一个有点权 ...

  3. Luogu P4768 [NOI2018]归程(Dijkstra+Kruskal重构树)

    P4768 [NOI2018]归程 题面 题目描述 本题的故事发生在魔力之都,在这里我们将为你介绍一些必要的设定. 魔力之都可以抽象成一个 \(n\) 个节点. \(m\) 条边的无向连通图(节点的编 ...

  4. [洛谷P4768] [NOI2018]归程 (kruskal重构树模板讲解)

    洛谷题目链接:[NOI2018]归程 因为题面复制过来有点炸格式,所以要看题目就点一下链接吧\(qwq\) 题意: 在一张无向图上,每一条边都有一个长度和海拔高度,小\(Y\)的家在\(1\)节点,并 ...

  5. 洛谷P4768 [NOI2018]归程(Kruskal重构树)

    题意 直接看题目吧,不好描述 Sol 考虑暴力做法 首先预处理出从$1$到每个节点的最短路, 对于每次询问,暴力的从这个点BFS,从能走到的点里面取$min$ 考虑如何优化,这里要用到Kruskal重 ...

  6. 洛谷$P4768\ [NOI2018]$归程 $kruscal$重构树

    正解:$kruscal$重构树 解题报告: 传送门$QwQ$ 语文不好选手没有人权$TT$连题目都看不懂真的要哭了$kk$ 所以先放个题目大意?就说给定一个$n$个点,$m$条边的图,每条边有长度和海 ...

  7. 洛谷 P4768 [NOI2018]归程

    洛谷 361行代码的由来 数据分治大发好啊- NOI的签到题,可怜我在家打了一下午才搞了80分. 正解应该是kruskal重构树或排序+可持久化并查集. 我就分点来讲暴力80分做法吧(毕竟正解我也没太 ...

  8. 洛谷P4768 [NOI2018]归程 [可持久化并查集,Dijkstra]

    题目传送门 归程 格式难调,题面就不放了. 分析: 之前同步赛的时候反正就一脸懵逼,然后场场暴力大战,现在呢,还是不会$Kruskal$重构树,于是就拿可持久化并查集做. 但是之前做可持久化并查集的时 ...

  9. 洛谷P4768 [NOI2018]归程(可持久化并查集,最短路)

    闲话 一个蒟蒻,在网络同步赛上进行了这样的表演-- T2组合计数不会,T3字符串数据结构不会,于是爆肝T1 一开始以为整个地图都有车,然后写了2h+的树套树,终于发现样例过不去 然后写可持久化并查集D ...

随机推荐

  1. ruby 精选网站

    ruby 基础   http://www.yiibai.com/ruby/2013/0820174.html     http://www.rubydoc.info/github       http ...

  2. Kattis - cardhand Card Hand Sorting 【暴力枚举】

    题意 给出 一个扑克牌的序列 求排成一个"有序"序列 最少的插入次数 有序是这样定义的 同一个花色的 必须放在一起 同一花色中的牌 必须是 升序 或者是 降序 然后 A 是最大的 ...

  3. OTA升级

    除了云端平台这部分,还要有通讯协议层面.云端和汽车端之间指令的接口和协议的制定,不同车厂会有不同诉求.艾拉比既可以支持车厂私有化定制协议的要求,也可以提供基于OMA标准的协议. 第一,它既是云端的工具 ...

  4. 统一ID服务

    代码已经修改 调用方式 为restful请求  或者 feign请求  请参考 wiki:   http://192.168.120.46:8090/display/peixun/akucun+Gui ...

  5. mooc_java 集合框架下

    1.判断List中课程是否存在 /** * 测试List的contains方法 * @param args */ public void testListContains(){ Course cour ...

  6. .net中后台c#数组与前台js数组交互

    第一步:定义cs数组  cs文件里后台程序中要有数组,这个数组要定义成公共的数组.  public string[] lat = null;  public string[] lng = null; ...

  7. linux应用之Lamp(apache+mysql+php)的源码安装(centos)

    Linux+Apache+Mysql+Php源码安装 一.安装环境: 系统:Centos6.5x64 Apache: httpd-2.4.10.tar.gz Mysql: mysql-5.6.20-l ...

  8. Python连接Mysql数据库_20160928

    python版本 2.7.1,python 连接mysql需要安装MYSQLdb模块 安装方法一种是cmd pip命令安装 pip install MySQLdb 一种是网上下载python MYSQ ...

  9. COGS 2581 无聊的会议V2

    传送 题目大意 给定一个长为\(n\)的序列,定义\(y\)在三元对\((x,y,z)\)中成为中心轴当且仅当同时满足:\(a_x = a_y = a_z,y-x=z-y,x<y<z\)对 ...

  10. bzoj 3073 [Pa2011]Journeys ——线段树优化连边

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3073 建两棵线段树,一棵孩子向父亲连边,是走出去的:一棵父亲向孩子连边,是走进来的. 注意第 ...