luoguP1505 [国家集训队]旅游(真的毒瘤)
#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 [国家集训队]旅游(真的毒瘤)的更多相关文章
- 洛谷 P1505 [国家集训队]旅游 解题报告
P1505 [国家集训队]旅游 题目描述 \(\tt{Ray}\) 乐忠于旅游,这次他来到了\(T\)城.\(T\)城是一个水上城市,一共有 \(N\) 个景点,有些景点之间会用一座桥连接.为了方便游 ...
- 树链剖分【洛谷P1505】 [国家集训队]旅游
P1505 [国家集训队]旅游 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城 ...
- 洛谷 P1505 [国家集训队]旅游 树链剖分
目录 题面 题目链接 题目描述 输入输出格式 输入格式 输出格式 输入输出样例 输入样例: 输出样例: 说明 思路 AC代码 总结 题面 题目链接 P1505 [国家集训队]旅游 题目描述 Ray 乐 ...
- ⌈洛谷1505⌋⌈BZOJ2157⌋⌈国家集训队⌋旅游【树链剖分】
题目链接 [洛谷] [BZOJ] 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T ...
- 2018.06.29 洛谷P1505 [国家集训队]旅游(树链剖分)
旅游 题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有 ...
- P1505 [国家集训队]旅游
\(\color{#0066ff}{题 目 描 述}\) Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了 ...
- 树链剖分【p1505】[国家集训队]旅游
Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间 ...
- 洛谷P1505 [国家集训队]旅游
题目描述 \(Ray\) 乐忠于旅游,这次他来到了\(T\) 城.\(T\) 城是一个水上城市,一共有 \(N\) 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,\(T ...
- P1505 [国家集训队]旅游[树剖]
题目描述 Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间有且只有一条路 ...
随机推荐
- fullpage.js版本3.0.5报错问题(licenseKey)
在文件里搜索licenseKey,删除!不会对程序造成任何影响
- (转)Centos7下杀毒软件clamav的安装和使用
本文转载自:https://www.cnblogs.com/bingo1024/p/9018212.html#_label1_0 目录 一.yum安装 二.编译安装 2.1:下载软件包 2.2:创建c ...
- DDD领域驱动设计初探(一):聚合
前言:又有差不多半个月没写点什么了,感觉这样很对不起自己似的.今天看到一篇博文里面写道:越是忙人越有时间写博客.呵呵,似乎有点道理,博主为了证明自己也是忙人,这不就来学习下DDD这么一个听上去高大上的 ...
- 了解卷积神经网络如何使用TDA学习
在我之前的文章中,我讨论了如何对卷积神经网络(CNN)学习的权重进行拓扑数据分析,以便深入了解正在学习的内容以及如何学习它. 这项工作的重要性可归纳如下: 它使我们能够了解神经网络如何执行分类任务. ...
- 在 CentOS 上部署 GitLab (自托管的Git项目仓库)
参考资料https://github.com/mattias-ohlsson/gitlab-installer/blob/master/gitlab-install-el6.sh 环境准备OS: Ce ...
- matplotlib--直线和点
直线和点: import matplotlib.pyplot as plt import numpy as np x=np.linspace(-10,10,10) y=x**2 h=plt.plot( ...
- python封装成exe
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/qq_32113189/article ...
- man fdisk
FDISK(8) Linux Programmer?. Manual/Linux程序手册 FDISK(8) NAME/名称 fdisk - Partition ta ...
- Task9.Attention
注意力模型最近几年在深度学习各个领域被广泛使用,无论是图像处理.语音识别还是自然语言处理的各种不同类型的任务中,都很容易遇到注意力模型的身影.所以,了解注意力机制的工作原理对于关注深度学习技术发展的技 ...
- asp.net+扫描仪+图片上传
问题: IE浏览器下使用Activex插件调用客户端扫描仪扫描文件并山传,可以将纸质档案(如合同.文件.资料等)扫描并将扫描图像保存到服务器,可以用于合同管理.档案管理等. 通过插件方式调用扫描仪扫描 ...