QTREE 树链剖分---模板 spoj QTREE
《树链剖分及其应用》 一文讲得非常清楚,我一早上就把他学会了并且A了这题的入门题。
spoj QTREE
题目:
给出一棵树,有两种操作:
1.修改一条边的边权。
2.询问节点a到b的最大边权。
直接粘代码。更成熟的代码可以看下一篇BZOJ 1036: [ZJOI2008]树的统计Count
#include <set>
#include <map>
#include <list>
#include <cmath>
#include <queue>
#include <stack>
#include <string>
#include <vector>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std; typedef long long ll;
typedef unsigned long long ull; #define debug puts("here")
#define rep(i,n) for(int i=0;i<n;i++)
#define rep1(i,n) for(int i=1;i<=n;i++)
#define REP(i,a,b) for(int i=a;i<=b;i++)
#define foreach(i,vec) for(unsigned i=0;i<vec.size();i++)
#define pb push_back
#define RD(n) scanf("%d",&n)
#define RD2(x,y) scanf("%d%d",&x,&y)
#define RD3(x,y,z) scanf("%d%d%d",&x,&y,&z)
#define RD4(x,y,z,w) scanf("%d%d%d%d",&x,&y,&z,&w)
#define All(vec) vec.begin(),vec.end()
#define MP make_pair
#define PII pair<int,int>
#define PQ priority_queue
#define cmax(x,y) x = max(x,y)
#define cmin(x,y) x = min(x,y)
#define Clear(x) memset(x,0,sizeof(x))
/* #pragma comment(linker, "/STACK:1024000000,1024000000") int size = 256 << 20; // 256MB
char *p = (char*)malloc(size) + size;
__asm__("movl %0, %%esp\n" :: "r"(p) ); */ /******** program ********************/ const int MAXN = ; int val[MAXN];
int po[MAXN],tol;
bool use[MAXN];
int n; struct node{
int y,c,next;
}edge[MAXN]; inline void add(int x,int y,int c){
edge[++tol].y = y;
edge[tol].c = c;
edge[tol].next = po[x];
po[x] = tol;
} struct tc{ // tree chain subdivision
int sz; // x子树大小
int dep; // 节点x的深度
int top; // 节点x所在链的顶端节点
int fa; // 节点x的父亲
int son; // 重儿子
int tid; // 在线段树中的位置
}p[MAXN]; void dfsFind(int x,int fa,int dep){
use[x] = true;
p[x].dep = dep;
p[x].sz = ;
p[x].son = ;
p[x].fa = fa; int mx = ;
for(int i=po[x];i;i=edge[i].next){
int y = edge[i].y;
if(use[y])continue;
dfsFind(y,x,dep+);
p[x].sz += p[y].sz;
if(p[y].sz>mx){
p[x].son = y;
mx = p[y].sz;
}
}
} int tid;
void dfsCon(int x,int fa){
use[x] = true;
p[x].tid = ++ tid;
p[x].top = fa;
if(p[x].son)
dfsCon(p[x].son,fa);
for(int i=po[x];i;i=edge[i].next){
int y = edge[i].y;
if(use[y])continue;
dfsCon(y,y);
}
} struct Tree{
int l,r,mx;
inline int mid(){
return (l+r)>>;
}
}tree[MAXN<<]; inline void update(int rt){
tree[rt].mx = max(tree[rt<<].mx,tree[rt<<|].mx);
} void build(int l,int r,int rt){
tree[rt].l = l;
tree[rt].r = r;
if(l==r){
tree[rt].mx = val[l];
return;
}
int mid = tree[rt].mid();
build(l,mid,rt<<);
build(mid+,r,rt<<|); update(rt);
} void modify(int pos,int c,int rt){
if(tree[rt].l==tree[rt].r){
tree[rt].mx = c;
return;
}
int mid = tree[rt].mid();
if(pos<=mid)
modify(pos,c,rt<<);
else
modify(pos,c,rt<<|); update(rt);
} int ask(int l,int r,int rt){
if(tree[rt].l==l&&tree[rt].r==r)
return tree[rt].mx;
int mid = tree[rt].mid();
if(r<=mid)
return ask(l,r,rt<<);
else if(l>mid)
return ask(l,r,rt<<|);
else
return max( ask(l,mid,rt<<),ask(mid+,r,rt<<|) );
} int main(){ #ifndef ONLINE_JUDGE
freopen("sum.in","r",stdin);
//freopen("sum.out","w",stdout);
#endif int x,y,z,ncase;
RD(ncase);
while(ncase--){
RD(n);
Clear(po);
tol = ; REP(i,,n){
RD3(x,y,z);
add(x,y,z);
add(y,x,z);
} Clear(use);
dfsFind(,,); tid = ;
Clear(use);
dfsCon(,); for(int i=;i<tol;i+=){
int x = edge[i^].y; // 对应于第x条边的节点 (x,y)
int y = edge[i].y; if(p[x].dep>p[y].dep)
val[ p[x].tid ] = edge[i].c;
else
val[ p[y].tid ] = edge[i].c;
} build(,n,); char op[];
while(scanf("%s",op),op[]!='D'){ if(op[]=='C'){
RD2(x,z);
y = edge[x<<].y;
x = edge[x<<|].y; if( p[x].dep>p[y].dep )
modify( p[x].tid,z, );
else
modify( p[y].tid,z, );
}else{
RD2(x,y);
int ans = -(<<);
while( p[x].top != p[y].top ){
if( p[ p[x].top ].dep < p[ p[y].top ].dep )
swap(x,y);
ans = max(ans,ask(p[ p[x].top ].tid,p[x].tid,));
x = p[ p[x].top ].fa;
}
if(p[x].dep>p[y].dep)
swap(x,y);
if(x!=y)
ans = max(ans,ask(p[x].tid+,p[y].tid,));
printf("%d\n",ans);
}
}
} return ;
}
QTREE 树链剖分---模板 spoj QTREE的更多相关文章
- BZOJ 2243 染色 | 树链剖分模板题进阶版
BZOJ 2243 染色 | 树链剖分模板题进阶版 这道题呢~就是个带区间修改的树链剖分~ 如何区间修改?跟树链剖分的区间询问一个道理,再加上线段树的区间修改就好了. 这道题要注意的是,无论是线段树上 ...
- 算法复习——树链剖分模板(bzoj1036)
题目: 题目背景 ZJOI2008 DAY1 T4 题目描述 一棵树上有 n 个节点,编号分别为 1 到 n ,每个节点都有一个权值 w .我们将以下面的形式来要求你对这棵树完成一些操作:I.CHAN ...
- Hdu 5274 Dylans loves tree (树链剖分模板)
Hdu 5274 Dylans loves tree (树链剖分模板) 题目传送门 #include <queue> #include <cmath> #include < ...
- SPOJ QTREE - Query on a tree 【树链剖分模板】
题目链接 引用到的大佬博客 代码来自:http://blog.csdn.net/jinglinxiao/article/details/72940746 具体算法讲解来自:http://blog.si ...
- SPOJ QTREE Query on a Tree【树链剖分模板题】
树链剖分,线段树维护~ #include <cstdio> #include <cstring> #include <iostream> #include < ...
- SPOJ 375 Query on a tree(树链剖分)(QTREE)
You are given a tree (an acyclic undirected connected graph) with N nodes, and edges numbered 1, 2, ...
- SPOJ QTREE 树链剖分
树链剖分的第一题,易懂,注意这里是边. #include<queue> #include<stack> #include<cmath> #include<cs ...
- Spoj Query on a tree SPOJ - QTREE(树链剖分+线段树)
You are given a tree (an acyclic undirected connected graph) with N nodes, and edges numbered 1, 2, ...
- SPOJ375.QTREE树链剖分
题意:一个树,a b c 代表a--b边的权值为c.CHANGE x y 把输入的第x条边的权值改为y,QUERY x y 查询x--y路径上边的权值的最大值. 第一次写树链剖分,其实树链剖分只能说 ...
随机推荐
- Java transient、Volatile关键字
Volatile修饰的成员变量在每次被线程访问时,都强迫从主内存中重读该成员变量的值.而且,当成员变量发生变化时,强迫线程将变化值回写到主内存.这样在任何时刻,两个不同的线程总是看到某个成员变量的同一 ...
- EasyUI datagrid添加右键菜单项
js代码 //动态加载数据表格 function InitData() { $('#grid').datagrid({ url: '/Home/Query?r=' + Math.random(), / ...
- C# Dictionary用法总结
转自:http://www.cnblogs.com/linlf03/archive/2011/12/09/2282574.html http://www.cnblogs.com/linzheng/ar ...
- 剑指OFFER之用两个栈实现队列(九度OJ1512)
题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 输入: 每个输入文件包含一个测试样例.对于每个测试样例,第一行输入一个n(1<=n<=100 ...
- Hibernate 中createQuery与createSQLQuery
本文原址 : http://stta04.javaeye.com/blog/377633 hibernate 中createQuery与createSQLQuery 昨晚帮同事看代码到凌晨2点多,今早 ...
- javascript --学习this
this 在一般的强类型语言中,this指向的是这个对象本身,可在javascript中 this的取值是执行上下文环境的一部分 其实这个this并不是很难立即,只要记住二点就可以了 那就是谁call ...
- Node.js Crypto 加密算法库
Crypto库是随Nodejs内核一起打包发布的,主要提供了加密.解密.签名.验证等功能.Crypto利用OpenSSL库来实现它的加密技术,它提供OpenSSL中的一系列哈希方法,包括hmac.ci ...
- 一个非常标准的Java连接Oracle数据库的示例代码
最基本的Oracle数据库连接代码(只针对Oracle11g): 1.右键项目->构建路径->配置构建路径,选择第三项“库”,然后点击“添加外部Jar”,选择“D:\Oracle\app\ ...
- 【转】教你Ruby快速入门
转自:http://developer.51cto.com/art/200703/41243.htm 介绍 这是一个短小的Ruby入门,完全读完只需20分钟.这里假设读者已经安装了Ruby,如果你没有 ...
- Posting data to a HttpHandler greater then ~29MB gives a 404 error
1down votefavorite 1 I am testing a HttpHandler that accepts XML. It works fine when a small amount ...