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. VPS 安装MySQL

    目前Centos下默认支持的数据库是MariaDB,MariaDB是mysql的增强版本,由于mysql被Oracle收购之后,mysql之父担心之后mysql会变成闭源的软件,就又开发了这个版本,支 ...

  2. Test 7.12 T2

    题目描述 ​ 有一张 n 个点 m 条边的无向图,其中有 s 个点上有加油站.有 Q 次询问(a,b,c), 问能否开一辆油箱容积为 c 的车从 a 走到 b. 输入格式 ​ 第一行三个整数 n,s, ...

  3. 使用vue进行国际化

    相对于网站等一些需求 我们有需要做国际化的需求,具体步骤如下: 首先安装 vue-i18n npm install vue-i18n import VueI18n from 'vue-i18n' Vu ...

  4. 配置Android Studio

    1.去gradle官网下载gradle,gradle的版本可以在C:\Program Files\Android\Android Studio\gradle下看到 2.新建一个项目,退出后把下载好的g ...

  5. namedtuple的简单使用

    """ factory function for creating tuple subclasses with named fields namedtuple 是tupl ...

  6. 让Flash内心崩溃的HTML5历史

    对于HTML5,在今天这个互联网时代,大部分人应该至少都听说过这个名字,或许很多人对HTML5的了解都起于一句话:FLASH杀手. HTML5其实早已不是什么新鲜的事物了,其最初的雏形早在2004年就 ...

  7. 2018 ACM-ICPC 中国大学生程序设计竞赛线上赛 D Merchandise (斜率优化)

    Description: The elderly aunts always like to look for bargains and preferential merchandise. Now th ...

  8. POJ 1511 Invitation Cards ( 双向单源最短路 || 最小来回花费 )

    题意 : 给出 P 个顶点以及 Q 条有向边,求第一个点到其他各点距离之和+其他各点到第一个点的距离之和的最小值 分析 : 不难看出 min( 第一个点到其他各点距离之和+其他各点到第一个点的距离之和 ...

  9. FastDFS介绍(一)

    1.简介 FastDFS对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载.文件删除)等,解决了大容量文件存储的问题,特别适合以文件为载体的在线服务,如相册网站.文档网站.图片 ...

  10. linux nginx+php源码安装

    PHP安装 1)下载 wget http://cn2.php.net/distributions/php-5.6.30.tar.gz 2)解压 tar –xf php-5.6.30 3)进入目录 cd ...