2019.01.21 洛谷P3919 【模板】可持久化数组(主席树)
传送门
题意简述:支持在某个历史版本上修改某一个位置上的值,访问某个历史版本上的某一位置的值。
思路:
用主席树直接维护历史版本即可。
代码:
#include<bits/stdc++.h>
#define ri register int
using namespace std;
inline int read(){
	int ans=0,w=1;
	char ch=getchar();
	while(!isdigit(ch)){if(ch=='-')w=-1;ch=getchar();}
	while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
	return ans*w;
}
const int N=1e6+5;
int n,m,rt[N],a[N];
namespace SGT{
	#define lc (son[p][0])
	#define rc (son[p][1])
	#define mid (l+r>>1)
	int son[N*20][2],val[N*20],tot=0;
	inline void build(int&p,int l,int r){
		p=++tot;
		if(l==r){val[p]=a[l];return;}
		build(lc,l,mid),build(rc,mid+1,r);
	}
	inline void update(int&p,int o,int l,int r,int k,int v){
		p=++tot,lc=son[o][0],rc=son[o][1];
		if(l==r){val[p]=v;return;}
		k<=mid?update(lc,son[o][0],l,mid,k,v):update(rc,son[o][1],mid+1,r,k,v);
	}
	inline int query(int p,int l,int r,int k){
		if(l==r)return val[p];
		return k<=mid?query(lc,l,mid,k):query(rc,mid+1,r,k);
	}
}
int main(){
	n=read(),m=read();
	for(ri i=1;i<=n;++i)a[i]=read();
	SGT::build(rt[0],1,n);
	for(ri op,id,x,i=1;i<=m;++i){
		id=read(),op=read(),x=read(),rt[i]=rt[id];
		switch(op){
			case 1:SGT::update(rt[i],rt[id],1,n,x,read());break;
			default:cout<<SGT::query(rt[i],1,n,x)<<'\n';
		}
	}
	return 0;
}
												
											2019.01.21 洛谷P3919 【模板】可持久化数组(主席树)的更多相关文章
- P3919 (模板)可持久化数组 (主席树)
		
题目链接 Solution 主席树水题,连差分的部分都不需要用到. 直接用主席树的结构去存一下就好了. Code #include<bits/stdc++.h> #define mid ( ...
 - 【洛谷P3919】可持久化数组
		
题目大意:需要维护一个长度为 N 的数组,支持在历史版本上单点修改和单点查询. 题解:显然,如果直接暴力维护的话会 MLE.因此,采用线段树进行维护,使得空间复杂度由 \(O(mn)\) 降至 \(O ...
 - luogu P3919 [模板]可持久化数组(可持久化线段树/平衡树)(主席树)
		
luogu P3919 [模板]可持久化数组(可持久化线段树/平衡树) 题目 #include<iostream> #include<cstdlib> #include< ...
 - 洛谷P3919 【模板】可持久化数组 [主席树]
		
题目传送门 可持久化数组 题目描述 如题,你需要维护这样的一个长度为 $N$ 的数组,支持如下几种操作 在某个历史版本上修改某一个位置上的值 访问某个历史版本上的某一位置的值 此外,每进行一次操作(对 ...
 - LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)
		
为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...
 - 洛谷P2633 Count on a tree(主席树上树)
		
题目描述 给定一棵N个节点的树,每个点有一个权值,对于M个询问(u,v,k),你需要回答u xor lastans和v这两个节点间第K小的点权.其中lastans是上一个询问的答案,初始为0,即第一个 ...
 - 洛谷P4587 [FJOI2016]神秘数(主席树)
		
题面 洛谷 题解 考虑暴力,对于询问中的一段区间\([l,r]\),我们先将其中的数升序排序,假设当前可以表示出\([1,k]\)目前处理\(a_i\),假如\(a_i>k+1\),则答案就是\ ...
 - 【洛谷2839/BZOJ2653】middle(主席树)
		
题目: 洛谷2839 分析: 记\(s_i\)表示原序列中第\(i\)大的数. 考虑对于任意一个区间\([a,b]\),设它的中位数为\(s_m\),那么这个区间内大于等于\(s_m\)的数和小于\( ...
 - LOJ 2555 & 洛谷 P4602 [CTSC2018]混合果汁(二分+主席树)
		
LOJ 题目链接 & 洛谷题目链接 题意:商店里有 \(n\) 杯果汁,第 \(i\) 杯果汁有美味度 \(d_i\),单价为 \(p_i\) 元/升.最多可以添加 \(l_i\) 升.有 \ ...
 
随机推荐
- Codeforces Beta Round #44 (Div. 2)
			
Codeforces Beta Round #44 (Div. 2) http://codeforces.com/contest/47 A #include<bits/stdc++.h> ...
 - TZOJ 3659 神奇的探险之旅(有向无环每个点只能经过一次最长路dij)
			
描述 我们正在设计这样的一款儿童探险游戏:游戏由很多故事场景组成,每个场景中都有一个问题,游戏根据玩家的回答将进入下一场景,经过巧妙的设计,我们保证在一次“探险旅行”中,不会重复的进入任何相同的场景, ...
 - c#: PointToClient与PointToScreen
			
起因: 很早就见过这两个方法,却未曾深入研究,偶尔一用,却纠结于其转换方法,遂写Demo以求验证,记录认知以做备忘. 其为Control类的内置方法,原型为: // // 摘要: // 将指定屏幕点的 ...
 - To be a better me
			
2017.4.15 突然成为前端实习生.做了两个周的官网项目,主要是更新官网一些文字图片以及新加一个页面,因为是静态页面,所以熟悉了代码就上手了.幸好没出什么差错. 两周后,实习结束. 2017.7. ...
 - nginx配置websocket
			
有时候我们需要给websocket服务端做一下nginx的配置,比如需要给websocket服务端做负载均衡,或者,有些系统要求访问websocket的时候不能带端口,这时候我们就需要用nginx来进 ...
 - redis  集群java.lang.NoSuchMethodError:SpringJAR包版本冲突错误解决方法
			
项目中出现如下错误,记录下解决方法: org.springframework.beans.factory.BeanDefinitionStoreException: Unexpected exce ...
 - Python爬虫项目--爬取某宝男装信息
			
本次爬取用到的知识点有: 1. selenium 2. pymysql 3 pyquery 正文 1. 分析目标网站 1. 打开某宝首页, 输入"男装"后点击"搜索&q ...
 - go语言net包udp socket的使用
			
udp与tcp的不同在于客户端请求方式不同,udp缺少Accept函数. 一个简单的udp客户端: package main; import ( "net" "log&q ...
 - C语言中简单的for循环和浮点型变量
			
浮点型变量:常数中带有小数点的叫做浮点型 以下用for循环写一个摄氏度和华氏度的转换的C程序 [见 http://www.linuxidc.com/Linux/2013-08/88513.htm ] ...
 - Android Studio 使用入门
			
Android Studio 快捷键 Action Mac OSX Win/Linux 注释代码(//) Cmd + / Ctrl + / 注释代码(/**/) Cmd + Option + / Ct ...