luogu P1505 [国家集训队]旅游 题目

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define mem(Arr,x) memset(Arr,x,sizeof(Arr))
const int maxN=;
const int maxM=maxN*;
const int inf=;
class SegmentData
{
public:
int sum;
int mn,mx;
int mega;
};
int n;
int edgecnt=,Head[maxN],Next[maxM],V[maxM],W[maxM];
int Fa[maxN],Size[maxN],Hson[maxN],Top[maxN],Faedge[maxN],Depth[maxN];
int idcnt=,Id[maxN];
SegmentData S[maxN*];
void Add_Edge(int u,int v,int w);
void _Add(int u,int v,int w);
void dfs1(int u);
void dfs2(int u,int top);
int QC_max(int u,int v);//查询路径最大值
int QC_min(int u,int v);//查询路径最小值
int QC_sum(int u,int v);//查询路径和
void QC_nega(int u,int v);//把路径上所有边权取负
void PushDown(int now);//线段树下放标记
void Update(int now);//线段树更新
void Modify(int now,int l,int r,int pos,int key);//线段树单点修改
void Makenega(int now,int l,int r,int ql,int qr);//线段树区间取负
int Query_max(int now,int l,int r,int ql,int qr);//线段树区间最大
int Query_min(int now,int l,int r,int ql,int qr);//线段树区间最小
int Query_sum(int now,int l,int r,int ql,int qr);//线段树区间求和
int main(){
mem(Head,-);
scanf("%d",&n);
for (int i=;i<n;i++){
int u,v,w;scanf("%d%d%d",&u,&v,&w);u++;v++;
Add_Edge(u,v,w);
}
Depth[]=;
dfs1();
dfs2(,);
int Q;scanf("%d",&Q);
char opt[];
while (Q--){
scanf("%s",opt);
if (opt[]=='C'){
int pos,key;scanf("%d%d",&pos,&key);pos++;
pos=Id[pos];
Modify(,,n,pos,key);
}
if (opt[]=='N'){
int u,v;scanf("%d%d",&u,&v);u++;v++;
QC_nega(u,v);
}
if (opt[]=='S'){
int u,v;scanf("%d%d",&u,&v);u++;v++;
printf("%d\n",QC_sum(u,v));
}
if (opt[]=='A'){
int u,v;scanf("%d%d",&u,&v);u++;v++;
printf("%d\n",QC_max(u,v));
}
if (opt[]=='I'){
int u,v;scanf("%d%d",&u,&v);u++;v++;
printf("%d\n",QC_min(u,v));
}
}
return ;
}
void Add_Edge(int u,int v,int w)
{
_Add(u,v,w);_Add(v,u,w);return;
}
void _Add(int u,int v,int w){
edgecnt++;Next[edgecnt]=Head[u];Head[u]=edgecnt;V[edgecnt]=v;W[edgecnt]=w;
return;
}
void dfs1(int u){
Size[u]=;
for (int i=Head[u];i!=-;i=Next[i])
if (V[i]!=Fa[u]){
Fa[V[i]]=u;Faedge[V[i]]=W[i];
Depth[V[i]]=Depth[u]+;
dfs1(V[i]);
Size[u]+=Size[V[i]];
if (Size[V[i]]>Size[Hson[u]]) Hson[u]=V[i];
}
return;
} void dfs2(int u,int top){
Id[u]=++idcnt;
Modify(,,n,idcnt,Faedge[u]);
Top[u]=top;
if (Hson[u]==) return;
dfs2(Hson[u],top);
for (int i=Head[u];i!=-;i=Next[i])
if ((V[i]!=Fa[u])&&(V[i]!=Hson[u])) dfs2(V[i],V[i]);
return;
} int QC_max(int u,int v){
int ret=-inf;
while (Top[u]!=Top[v]){
if (Depth[Top[u]]<Depth[Top[v]]) swap(u,v);
ret=max(ret,Query_max(,,n,Id[Top[u]],Id[u]));
u=Fa[Top[u]];
}
if (Depth[u]>Depth[v]) swap(u,v);
if (u!=v) ret=max(ret,Query_max(,,n,Id[u]+,Id[v]));
return ret;
} int QC_min(int u,int v){
int ret=inf;
while (Top[u]!=Top[v]){
if (Depth[Top[u]]<Depth[Top[v]]) swap(u,v);
ret=min(ret,Query_min(,,n,Id[Top[u]],Id[u]));
u=Fa[Top[u]];
}
if (Depth[u]>Depth[v]) swap(u,v);
if (u!=v) ret=min(ret,Query_min(,,n,Id[u]+,Id[v]));
return ret;
} int QC_sum(int u,int v){
int ret=;
while (Top[u]!=Top[v]){
if (Depth[Top[u]]<Depth[Top[v]]) swap(u,v);
ret=ret+Query_sum(,,n,Id[Top[u]],Id[u]);
u=Fa[Top[u]];
}
if (Depth[u]>Depth[v]) swap(u,v);
if (u!=v) ret=ret+Query_sum(,,n,Id[u]+,Id[v]);
return ret;
} void QC_nega(int u,int v){
while (Top[u]!=Top[v])
{
if (Depth[Top[u]]<Depth[Top[v]]) swap(u,v);
Makenega(,,n,Id[Top[u]],Id[u]);
u=Fa[Top[u]];
}
if (Depth[u]>Depth[v]) swap(u,v);
if (u!=v) Makenega(,,n,Id[u]+,Id[v]);
return;
} void PushDown(int now){
if (S[now].mega)
{
S[now].mega=;
int lson=now*,rson=now*+;
swap(S[lson].mx,S[lson].mn);swap(S[rson].mx,S[rson].mn);
S[lson].mx=-S[lson].mx;S[lson].mn=-S[lson].mn;
S[rson].mx=-S[rson].mx;S[rson].mn=-S[rson].mn;
S[lson].sum=-S[lson].sum;S[rson].sum=-S[rson].sum;
S[lson].mega^=;S[rson].mega^=;
}
return;
} void Update(int now){
int lson=now*,rson=now*+;
S[now].mx=max(S[lson].mx,S[rson].mx);
S[now].mn=min(S[lson].mn,S[rson].mn);
S[now].sum=S[lson].sum+S[rson].sum;
return;
} void Modify(int now,int l,int r,int pos,int key){
PushDown(now);
if (l==r){
S[now].mx=S[now].mn=S[now].sum=key;
return;
}
int mid=(l+r)/;
if (pos<=mid) Modify(now*,l,mid,pos,key);
if (pos>=mid+) Modify(now*+,mid+,r,pos,key);
Update(now);return;
} void Makenega(int now,int l,int r,int ql,int qr){
PushDown(now);
if ((l==ql)&&(r==qr)){
S[now].mega^=;swap(S[now].mx,S[now].mn);
S[now].mx=-S[now].mx;S[now].mn=-S[now].mn;
S[now].sum=-S[now].sum;
return;
}
int mid=(l+r)/;
if (qr<=mid) Makenega(now*,l,mid,ql,qr);
else if (ql>=mid+) Makenega(now*+,mid+,r,ql,qr);
else{
Makenega(now*,l,mid,ql,mid);Makenega(now*+,mid+,r,mid+,qr);
}
Update(now);return;
} int Query_max(int now,int l,int r,int ql,int qr){
PushDown(now);
if ((l==ql)&&(r==qr)) return S[now].mx;
int mid=(l+r)/;
if (qr<=mid) return Query_max(now*,l,mid,ql,qr);
else if (ql>=mid+) return Query_max(now*+,mid+,r,ql,qr);
else return max(Query_max(now*,l,mid,ql,mid),Query_max(now*+,mid+,r,mid+,qr));
}
int Query_min(int now,int l,int r,int ql,int qr){
PushDown(now);
if ((l==ql)&&(r==qr)) return S[now].mn;
int mid=(l+r)/;
if (qr<=mid) return Query_min(now*,l,mid,ql,qr);
else if (ql>=mid+) return Query_min(now*+,mid+,r,ql,qr);
else return min(Query_min(now*,l,mid,ql,mid),Query_min(now*+,mid+,r,mid+,qr));
}
int Query_sum(int now,int l,int r,int ql,int qr){
PushDown(now);
if ((l==ql)&&(r==qr)) return S[now].sum;
int mid=(l+r)/;
if (qr<=mid) return Query_sum(now*,l,mid,ql,qr);
else if (ql>=mid+) return Query_sum(now*+,mid+,r,ql,qr);
else return Query_sum(now*,l,mid,ql,mid)+Query_sum(now*+,mid+,r,mid+,qr);
}

luoguP1505 [国家集训队]旅游(真的毒瘤)的更多相关文章

  1. 洛谷 P1505 [国家集训队]旅游 解题报告

    P1505 [国家集训队]旅游 题目描述 \(\tt{Ray}\) 乐忠于旅游,这次他来到了\(T\)城.\(T\)城是一个水上城市,一共有 \(N\) 个景点,有些景点之间会用一座桥连接.为了方便游 ...

  2. 树链剖分【洛谷P1505】 [国家集训队]旅游

    P1505 [国家集训队]旅游 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城 ...

  3. 洛谷 P1505 [国家集训队]旅游 树链剖分

    目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例: 输出样例: 说明 思路 AC代码 总结 题面 题目链接 P1505 [国家集训队]旅游 题目描述 Ray 乐 ...

  4. ⌈洛谷1505⌋⌈BZOJ2157⌋⌈国家集训队⌋旅游【树链剖分】

    题目链接 [洛谷] [BZOJ] 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T ...

  5. 2018.06.29 洛谷P1505 [国家集训队]旅游(树链剖分)

    旅游 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有 ...

  6. P1505 [国家集训队]旅游

    \(\color{#0066ff}{题 目 描 述}\) Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了 ...

  7. 树链剖分【p1505】[国家集训队]旅游

    Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间 ...

  8. 洛谷P1505 [国家集训队]旅游

    题目描述 \(Ray\) 乐忠于旅游,这次他来到了\(T\) 城.\(T\) 城是一个水上城市,一共有 \(N\) 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,\(T ...

  9. P1505 [国家集训队]旅游[树剖]

    题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有一条路 ...

随机推荐

  1. C#.Net 调用Java的Web Service

    首先,得有一个web service地址:http://www.baiduc.om/XXServices?wsdl 然后在.net 项目中添加Web引用,并把地址给它输进去 第三.编码: using ...

  2. wenzhang

    作者:周公子链接:https://zhuanlan.zhihu.com/p/94960418来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 2006年2月9日,首都经济 ...

  3. OGG-00664

    参数SID写错了 GGSCI (t2) > edit param exta extract exta setenv (NLS_LANG=AMERICAN_AMERICA.ZHS16GBK) se ...

  4. Vue.js 技术揭秘学习 (3) render

    Vue 的 _render 方法是实例的一个私有方法,它用来把实例渲染成一个虚拟 Node  ,返回的是一个VNode 在 Vue 的官方文档中介绍了 render 函数的第一个参数是 createE ...

  5. TreeMap和Comparable接口

    备注:HashMap线程不安全,效率高,允许key.value为空 HasTable线程安全.效率低.不允许key或value为空 TreeMap在存储时会自动调用comparable方法进行排序,当 ...

  6. 怎么在tensorflow中打印graph中的tensor信息

    from tensorflow.python import pywrap_tensorflow import os checkpoint_path=os.path.join('./model.ckpt ...

  7. selenium 自动化的坑(1)

    UI自动化,一天一坑系列(1) 不要试图自作聪明添加一些不必要的东西. 个人遇到的问题关于下拉框的,本来一个下拉框连续点击两次就好了,结果自己多余将谷歌的提示‘正在受到自动化控制’去掉了,导致原本很简 ...

  8. 【leetcode】1028. Recover a Tree From Preorder Traversal

    题目如下: We run a preorder depth first search on the root of a binary tree. At each node in this traver ...

  9. UI自动化前置代码

    一.前置代码: #导入包selenium from selenium import webdriverimport time#创键一个火狐对象driver=webdriver.Firefox()#防问 ...

  10. CSS中浮动属性float及清除浮动

    1.float属性 CSS 的 Float(浮动),会使元素向左或向右移动,由于浮动的元素会脱离文档流,所以它后面的元素会重新排列. 浮动元素之后的那些元素将会围绕它,而浮动元素之前的元素将不会受到影 ...