【做题记录】2025刷题计划--线段树

news/2025/1/19 11:19:22/文章来源:https://www.cnblogs.com/zhangxyhp/p/18679418

A. 「SDOI2014」旅行
给每个宗教开一棵线段树,树剖 \(+\) 线段树单点修改区间查询即可。

Code
#include<bits/stdc++.h>
#define ll long long
#define il inline
#define read(x){\char ch;\int fu=1;\while(!isdigit(ch=getchar()))\fu-=(ch=='-')<<1;\x=ch&15;\while(isdigit(ch=getchar()))\x=(x<<1)+(x<<3)+(ch&15);\x*=fu;\
}
#define int ll
#define pb push_back
using namespace std;
namespace asbt{
namespace cplx{bool begin;}
const int maxn=1e5+5,maxm=5e6+5;
int n,m,a[maxn],b[maxn],cnt;
int top[maxn],fa[maxn],dfn[maxn];
int sz[maxn],hes[maxn],dep[maxn];
vector<int> e[maxn];
il void dfs1(int u){dep[u]=dep[fa[u]]+1;sz[u]=1;int mxs=0;for(int v:e[u]){if(v==fa[u]){continue;}fa[v]=u;dfs1(v);sz[u]+=sz[v];if(mxs<sz[v]){mxs=sz[v];hes[u]=v;}}
}
il void dfs2(int u){dfn[u]=++cnt;if(!top[u]){top[u]=u;}if(hes[u]){top[hes[u]]=top[u];dfs2(hes[u]);}for(int v:e[u]){if(v==fa[u]||v==hes[u]){continue;}dfs2(v);}
}
int rt[maxn],ls[maxm],rs[maxm];
int tot,sum[maxm],mx[maxm];
il void pushup(int id){sum[id]=sum[ls[id]]+sum[rs[id]];mx[id]=max(mx[ls[id]],mx[rs[id]]);
}
il void upd(int &id,int l,int r,int pos,int val){if(!id){id=++tot;}if(l==r){sum[id]=mx[id]=val;return ;}int mid=(l+r)>>1;if(pos<=mid){upd(ls[id],l,mid,pos,val);}else{upd(rs[id],mid+1,r,pos,val);}pushup(id);
}
il int qsum(int id,int L,int R,int l,int r){if(!id){return 0;}if(L>=l&&R<=r){return sum[id];}int mid=(L+R)>>1,res=0;if(l<=mid){res+=qsum(ls[id],L,mid,l,r);}if(r>mid){res+=qsum(rs[id],mid+1,R,l,r);}return res;
}
il int qmx(int id,int L,int R,int l,int r){if(!id){return 0;}if(L>=l&&R<=r){return mx[id];}int mid=(L+R)>>1,res=0;if(l<=mid){res=max(res,qmx(ls[id],L,mid,l,r));}if(r>mid){res=max(res,qmx(rs[id],mid+1,R,l,r));}return res;
}
namespace cplx{bool end;il double usdmem(){return (&begin-&end)/10485796.0;}
}
signed main(){read(n)read(m);for(int i=1;i<=n;i++){read(a[i])read(b[i]);}for(int i=1,u,v;i<n;i++){read(u)read(v);e[u].pb(v),e[v].pb(u);}dfs1(1),dfs2(1);for(int i=1;i<=n;i++){upd(rt[b[i]],1,n,dfn[i],a[i]);}while(m--){char opt[5];int u,v;scanf(" %s",opt+1);read(u)read(v);switch(opt[2]){case 'C':{upd(rt[b[u]],1,n,dfn[u],0);b[u]=v;upd(rt[b[u]],1,n,dfn[u],a[u]);break;}case 'W':{a[u]=v;upd(rt[b[u]],1,n,dfn[u],a[u]);break;}case 'S':{int res=0,x=b[u];while(top[u]!=top[v]){
//					puts("666");if(dep[top[u]]<dep[top[v]]){swap(u,v);}res+=qsum(rt[x],1,n,dfn[top[u]],dfn[u]);u=fa[top[u]];}if(dep[u]>dep[v]){swap(u,v);}res+=qsum(rt[x],1,n,dfn[u],dfn[v]);printf("%lld\n",res);break;}default:{int res=0,x=b[u];while(top[u]!=top[v]){if(dep[top[u]]<dep[top[v]]){swap(u,v);}res=max(res,qmx(rt[x],1,n,dfn[top[u]],dfn[u]));u=fa[top[u]];}if(dep[u]>dep[v]){swap(u,v);}res=max(res,qmx(rt[x],1,n,dfn[u],dfn[v]));printf("%lld\n",res);break;}}}return 0;
}
}
signed main(){return asbt::main();}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/871647.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

NOIP 冲刺之——数据结构

\(\texttt{0x00}\) 前言 本篇文章主要记录笔者 NOIP 冲刺阶段复习的各种数据结构题型及 tricks ans tips,同时也用于及时复习与巩固。 那么,开始吧。 \(\texttt{0x01}\) 树状数组、线段树 知识点 \(1\):二维偏序 众所周知,逆序对可以用归并排序离线求,但是要求在线呢? 这…

windows 将docker desktop上镜像打包并通过资源管理器找到使用

在 Windows 上使用 Docker Desktop 时,可以通过以下步骤将 Docker 镜像保存为 .tar 文件,并通过资源管理器找到该文件:步骤 1:打开 Docker Desktop 确保 Docker Desktop 正在运行。如果未运行,请启动它。步骤 2:打开 PowerShell 或命令提示符按 Win + S,搜索 PowerShell…

解决方案 | office365/office 修复方法

打开控制面板,选择卸载程序,右键office 一般情况下,选择快速修复可以实现修复。如不行,那么选择联机修复‘。还是不行那就重装office

【pywinauto 库】启动PC端应用程序 - 上篇

一、简介 经过上一篇的学习、介绍和了解,想必小伙伴或者童鞋们,已经见识到pywinauto的强大了,今天继续介绍pywinauto,上一篇已经可以打开计算器了,这里宏哥再提供其他方法进行打开计算器和非电脑自带程序。pywinauto 可以启动电脑自带的应用程序,也可以启动电脑安装的应用…

【反EDR 】概要

一、什么是 EDR EDR 是“端点检测和响应”的缩写。它是部署在每台机器上的代理,用于观察操作系统生成的事件以识别攻击。如果检测到某些东西,它将生成警报并将其发送到 SIEM 或 SOAR,由人工分析师进行查看。“响应”是指在识别威胁后执行的操作,例如隔离主机,这不是本文的…

USB接口颜色都代表什么含义

手机充电器人人都有!充电器线颜色都不同!你知道不同颜色的USB接口的各个颜色都代表什么含义吗?大部分人都是不知道的,这篇文章让您 一目了然!建议收藏备用!以备不时之需!

Windows资源管理器Icon图标注入

免责声明 本文发布的工具和脚本,仅用作测试和学习研究,禁止用于商业用途,不能保证其合法性,准确性,完整性和有效性,请根据情况自行判断。简介 使用图标将 DLL 注入资源管理器的非正统和隐蔽方式 IconJector 这是一个Windows资源管理器DLL注入技术,使用Windows上的更改图…

ElasticSearch Query DSL(查询领域特定语言)

目录常用 DSL 关键字查询上下文相关度评分:_score源数据:_source数据源过滤器query 和 filter 上下文相关性评分 (relevance scores)query 的上下文filter 的上下文关于 query 和 filter 上下文的例子全文查询 (full text query)intervals 查询请求示例intervals的顶级参数ma…

ESP32 学习笔记(九)舵机实验

概念 舵机是一种位置(角度)伺服的驱动器,适用于那些需要角度不断变化并可以保持的控制系统。舵机只是一种通俗的叫法,其本质是一个伺服电机。 舵机有很多规格,但所有的舵机都有外接三根线,分别用棕、红、橙三种颜色进行区分,由于舵机品牌不同,颜色也会有所差异,棕色为…

(原创)[开源][.Net Standard 2.0] SimpleMMF (进程间通信框架)更新 v1.1,极低CPU占用

一、前言 在上一篇 (原创)[.Net] 进程间通信框架(基于共享内存)——SimpleMMF 中,发布了v1.0版,最大的问题是:CPU占用较高,至少40-50%。 这既与我的开发水平有关,也与SimpleMMF诞生环境有关,这个主要是用在数字孪生各软件之间同步数据,而部署软件的工作站性能都强悍…

Elasticsearch 笔记

目录ES 相关概念概述核心概念1)索引 index2)类型 type3) 字段 Filed4)映射 mapping5)文档 document6)集群 cluster7)节点 node8)分片和复制 shards & replicasDocker 中安装 ElasticSearch下载 ElasticSearch 和 Kibana配置启动 ElasticSearch单节点多节点启动开启 …

VMware Avi Load Balancer 31.1.1 发布 - 多云负载均衡平台

VMware Avi Load Balancer 31.1.1 发布 - 多云负载均衡平台VMware Avi Load Balancer 31.1.1 发布 - 多云负载均衡平台 应用交付:多云负载均衡、Web 应用防火墙和容器 Ingress 服务 请访问原文链接:https://sysin.org/blog/vmware-avi-load-balancer-31/ 查看最新版。原创作品…