HDU-6393 Traffic Network in Numazu
题意:给你一个n边n点的无向连通图,两个操作,操作一改变某个边的权值,操作二查询某两个点之间的路径长度。
题解:随便删掉环上一条边搞一棵树出来,因为两点间距离是两点各自到根的距离之和减去2*lca两点到根的距离。
所以修改操作就变为维护点到根这条链上的权值,差分一下 采用树状数组维护。
查询的时候就是用删掉那条边和不用两种情况,比较一下大小就好了。
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+;
int E[N],dfn[N],F[N],L[N],R[N],deep[N],inv[N],f[N][],to[N<<],w[N<<],nxt[N<<],H[N];
int W,X,Y,n,T,m,Q,x,y,z,tar,tot,cnt;
long long C[N];
void add(int u,int v,int z){
to[tot]=v,w[tot]=z,nxt[tot]=H[u],H[u]=tot++;
}
void dfs(int u,int fa,int deepth){
dfn[u]=L[u]=++cnt;
deep[u]=deepth;
inv[cnt]=u;
for(int i=H[u];~i;i=nxt[i]){
int v=to[i];
if(v==fa) continue;
if(dfn[v]) {
tar=(i>>)+;
W=w[i];
X=u;
Y=v;
continue;
}
f[v][]=u;
F[v]=w[i];
E[(i>>)+]=v;
dfs(v,u,deepth+);
}
R[u]=cnt;
}
void modify(int u,int v){
for(;u<=n;u+=u&(-u)) C[u]+=v;
}
long long sum(int u){
long long ans=;
for(;u;u-=u&(-u)) ans+=C[u];
return ans;
}
void work(){
for(int i=;i<;++i) for(int j=;j<=n;++j) f[j][i]=f[f[j][i-]][i-];
}
int lca(int x,int y){
if(deep[x]<deep[y]) swap(x,y);
int dt=deep[x]-deep[y];
for(int i=;i<;++i) if(dt&(<<i)) x=f[x][i];
if(x==y) return x;
for(int i=;i>=;--i) if(f[x][i]!=f[y][i]) x=f[x][i],y=f[y][i];
return f[x][];
}
long long dist(int x,int y){
return sum(dfn[x])+sum(dfn[y])-2LL*(sum(dfn[lca(x,y)]));
}
int main(){
for(scanf("%d",&T);T--;){
scanf("%d%d",&n,&m);
for(int i=;i<=n;++i) H[i]=-,dfn[i]=C[i]=;
tot=cnt=;
for(int i=;i<=n;++i){
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);
add(y,x,z);
}
dfs(,,);
work();
for(int i=;i<=n;++i) {
modify(L[inv[i]],F[inv[i]]);
modify(R[inv[i]]+,-F[inv[i]]);
}
while(m--){
scanf("%d%d%d",&x,&y,&z);
if(x==) {
if(tar==y) W=z;
else {
int i=E[y];
modify(L[i],z-F[i]);
modify(R[i]+,-z+F[i]);
F[i]=z;
}
}
else {
long long ans=dist(y,z);
ans=min(ans,dist(y,X)+dist(z,Y)+W);
ans=min(ans,dist(z,X)+dist(y,Y)+W);
printf("%lld\n",ans);
}
}
}
}
HDU-6393 Traffic Network in Numazu的更多相关文章
- HDU - 6393 Traffic Network in Numazu(树链剖分+基环树)
http://acm.hdu.edu.cn/showproblem.php?pid=6393 题意 给n个点和n条边的图,有两种操作,一种修改边权,另一种查询u到v的最短路. 分析 n个点和n条边,实 ...
- hdu 6393 Traffic Network in Numazu (树链剖分+线段树 基环树)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6393 思路:n个点,n条边,也就是基环树..因为只有一个环,我们可以把这个环断开,建一个新的点n+1与之相 ...
- HDU - 6393 Traffic Network in Numazu (LCA+RMQ+树状数组)
这道题相当于将这两题结合: http://poj.org/problem?id=2763 http://codeforces.com/gym/101808/problem/K 题意:有N各点N条边的带 ...
- HDU - 6393 Traffic Network in Numazu (基环树+树链剖分/LCA)
题意:给定一个带权边无向基环树,有两种操作,一种是改变某个边的权值,另一种是询问两点间的最短路径. 可以对环进行缩点,以环为根建立一棵新树,并记录与环相连的所有点和环上的哪个点相连,将路径分为环外和环 ...
- Traffic Network in Numazu
Traffic Network in Numazu 题目描述 Chika is elected mayor of Numazu. She needs to manage the traffic in ...
- HDU contest808 ACM多校第7场 Problem - 1008: Traffic Network in Numazu
首先嘚瑟一下这场比赛的排名:59 (第一次看到这么多 √ emmmm) 好了进入正文QAQ ...这道题啊,思路很清晰啊. 首先你看到树上路径边权和,然后还带修改,不是显然可以想到 树剖+线段树 维护 ...
- hdu6393 Traffic Network in Numazu 树链剖分
题目传送门 题意:给出n个点n条边的无向带权图,再给出两种操作,操作1是将第x条边的边权修改为y,操作2是询问点x到点y的最短路径. 思路:如果是n个点n-1条边,题目就变成了树,修改边权和询问最短路 ...
- hdu6393Traffic Network in Numazu【树状数组】【LCA】
Traffic Network in Numazu Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (J ...
- Method for finding shortest path to destination in traffic network using Dijkstra algorithm or Floyd-warshall algorithm
A method is presented for finding a shortest path from a starting place to a destination place in a ...
随机推荐
- 【集群实战】Rsync常见错误总结
1. 服务端指定模块没有对应目录 报错详情: @ERROR: chdir failed rsync error: error startingclient-server protocol (code ...
- AbstractQueuedSynchronizer与ReentrantLock
介绍 j.u.c包中的Lock定义了锁的行为. 而ReentrantLock是并发包下提供的一个锁的实现,它是一个可重入的.排他的锁. ReentrantLock有的属性也很简单,除了一个serial ...
- TCP连接过程及报文解析
可能大家都听过TCP建立连接时需要经历三次握手和四次挥手的. 那么具体的握手挥手的过程是怎么样的呢? 这篇文章就通过WireShark抓包来了解TCP连接建立和断开的过程. 实验方法: 写一段简单的代 ...
- PPT模板素材
http://588ku.com/sucai/0-dnum-0-54-0-1/
- 图论--差分约束--POJ 1201 Intervals
Intervals Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 30971 Accepted: 11990 Descripti ...
- The Preliminary Contest for ICPC Asia Xuzhou 2019 徐州网络赛 K题 center
You are given a point set with nn points on the 2D-plane, your task is to find the smallest number o ...
- unittest 管理接口用例(数据分离-读取excel)
1.公共模块 ---> login.xls """ common (package) ---> ReadFile.py """ ...
- postman(全局变量设置)
全局变量 全局变量作用于整个postman工具及所有环境 1.点击小齿轮进入到变量添加页面,点击Globals添加全局变量 2.输入变量名称和变量值 3.接口中设置变量 4.调用 Globals 变量 ...
- linux多线程入门
linux下的多线程通过pthread实现,下面给个简单的例子. #include <stdio.h> #include <stdlib.h> #include <pth ...
- QML设计飘散效果
1,目标及展示 首先希望实现文字.图片.控件等在触发后,呈现飘散并消失的效果.在QT例程<Qt Quick Particles Examples>是一个海星点击鼠标后呈现打散的效果,这个效 ...