竹马竹马chikuma
线段树合并
线段树中叶节点表示最大为该身价时可选人数,非叶节点维护最大值,答案即为shu[root[1]].mx。
插入只需将线段树从根到表示v[u]的节点路径上,mx全部取max ((1-v[u]-1)中最大值+1)即可。
合并时右儿子对左边的所有的max取max。
即为区间取最大值,单点修改,区间查询。
维护该子树中身价最多为i时最多可选人数。
代码如下:
#include<bits/stdc++.h>
using namespace std;
inline int read(){
int x=,f=;char c=getchar();
while(!isdigit(c)){if(c=='-')f=-;c=getchar();}
while(isdigit(c)){x=(x<<)+(x<<)+(c^);c=getchar();}
return f==?x:-x;
}
int cn;
const int N=2e5+;
struct segment_tree{
#define lc ch[p][0]
#define rc ch[p][1]
int t[N<<],ch[N<<][],tot,lazy[N<<];
void pushup(int p)
{
t[p]=max(t[lc],t[rc]);
}
void pushdown(int p)
{
if(lc)
{
t[lc]+=lazy[p];
lazy[lc]+=lazy[p];
}
if(rc)
{
t[rc]+=lazy[p];
lazy[rc]+=lazy[p];
}
lazy[p]=;
}
void merge(int &p,int pre,int l,int r,int lx,int ly){
if(!p && !pre) return;
if(!pre)
{
lazy[p]+=ly;
t[p]+=ly;
return;
}
if(!p)
{
lazy[pre]+=lx;
t[pre]+=lx;
p=pre;
return;
}
if(l==r)
{
t[p]+=max(ly,t[pre]);
return;
}
int mid=(l+r)>>;
pushdown(p);
pushdown(pre);
merge(rc,ch[pre][],mid+,r,max(lx,t[lc]),max(ly,t[ch[pre][]]));
merge(lc,ch[pre][],l,mid,lx,ly);
pushup(p);
}
void insert(int &p,int l,int r,int x,int v){
if(!p)p=++tot;
t[p]=max(t[p],v);
if(l==r)return;
int mid=l+r>>;
if(x<=mid) insert(lc,l,mid,x,v);
else insert(rc,mid+,r,x,v);
}
int query(int p,int l,int r,int ql,int qr){
if(!p)return ;
if(ql<=l&&r<=qr)return t[p];
int mid=l+r>>,ret=;
pushdown(p);
if(ql<=mid)ret=max(ret,query(lc,l,mid,ql,qr));
if(mid<qr)ret=max(ret,query(rc,mid+,r,ql,qr));
return ret;
}
}seg;
struct edge{
int v,nxt;
}e[N];
int first[N],cnt=;
inline void add(int u,int v){
e[++cnt].v=v;e[cnt].nxt=first[u];first[u]=cnt;
}
int n,a[N],b[N],rt[N];
inline void dfs(int x){
for(int i=first[x],v,v1,v2;i;i=e[i].nxt){
v=e[i].v;
dfs(v);
v1=v2=;
seg.merge(rt[x],rt[v],,cn,v1,v2);
}
seg.insert(rt[x],,cn,a[x],((a[x]==)?:(seg.query(rt[x],,cn,,a[x]-)+)));
}
int main(){
freopen("chikuma.in","r",stdin);
freopen("chikuma.out","w",stdout);
long long size = << ;
char *p = (char*)malloc(size) + size;
__asm__("movl %0, %%esp\n" :: "r"(p));
n=read();
for(int i=,x;i<=n;i++){
b[i]=a[i]=read();x=read();
if(x) add(x,i);
}
sort(b+,b+n+);
cn=unique(b+,b+n+)-b-;
for(int i=;i<=n;i++)
a[i]=lower_bound(b+,b+cn+,a[i])-b;
dfs();
cout<<seg.t[rt[]];
fclose(stdin);
fclose(stdout);
return ;
}
/*
6
3 0 1 1 2 1 3 1 4 1 5 1
*/
竹马竹马chikuma的更多相关文章
- [Swust OJ 772]--Friend(并查集+map的运用)
题目链接:http://acm.swust.edu.cn/problem/772/ Time limit(ms): 1000 Memory limit(kb): 65535 Descriptio ...
- python --常用内置模块01
1.简单了解模块 模块就是我们把装有特定功能的代码进行归类的解构,从代码编写的单位来看我们的程序 从小到大的顺序:一条代码< 语句块<代码块(函数,类) < 模块 我 ...
- qwq。。胡诌qwq
1,十里寒塘,红楼灯火阑珊,晓风残月,思念醒了一半. 晨钟催落月,淑气催黄鸟,而花千树而你还未还,三月烟花,只剩远影孤帆,珠箔飘灯,大雁独自来返,柳絮铺地,桃花落了菀晚, 琴声弹起,雨落长安,长夜漫漫 ...
- 佛山6397.7539(薇)xiaojie:佛山哪里有xiaomei
佛山哪里有小姐服务大保健[微信:6397.7539倩儿小妹[佛山叫小姐服务√o服务微信:6397.7539倩儿小妹[佛山叫小姐服务][十微信:6397.7539倩儿小妹][佛山叫小姐包夜服务][十微信 ...
- 宜宾1178.9873(薇)xiaojie:宜宾哪里有xiaomei
宜宾哪里有小姐服务大保健[微信:1178.9873倩儿小妹[宜宾叫小姐服务√o服务微信:1178.9873倩儿小妹[宜宾叫小姐服务][十微信:1178.9873倩儿小妹][宜宾叫小姐包夜服务][十微信 ...
随机推荐
- 2018-2-13-win10-uwp-ContentDialog-点确定不关闭
title author date CreateTime categories win10 uwp ContentDialog 点确定不关闭 lindexi 2018-2-13 17:23:3 +08 ...
- H3C HDLC配置
- H3C DR和BDR选举
- 【9103】求n的累加和
Time Limit: 10 second Memory Limit: 2 MB 问题描述 用高精度方法,求s=1+2+3+...+n的精确值(n以一般整数输入) Input 文件输入仅一行,输入n ...
- 【踩坑记录】vue单个组件内<style lang="stylus" type="text/stylus" scoped>部分渲染失效
vue组件化应用,近期写的单个组件里有一个的渲染部分样式渲染不上去 因为同结构的其他组件均没有问题,所以排除是.vue文件结构的问题,应该是<style>内部的问题 <style l ...
- D Thanking-Bear magic
题目描述 In order to become a magical girl, Thinking-Bear are learning magic circle. He first drew a reg ...
- 关于react的redux的知识点
项目小的时候我们getState()进行管理数据,只有当数据庞大的时候我们采用Redux来进行管理. Redux: ①:它是专注于状态管理的库,和React是解耦的 ②:它是单向数据流,单一的状态 ③ ...
- 2018宁夏邀请赛 L Continuous Intervals(单调栈+线段树)
2018宁夏邀请赛 L Continuous Intervals(单调栈+线段树) 传送门:https://nanti.jisuanke.com/t/41296 题意: 给一个数列A 问在数列A中有多 ...
- VRChat之转移地图缓存
我的电脑是win10,win10的缓存地址和名称可能和win7的名字有所不同. win10缓存路径:C:\Users\Administrator\AppData\LocalLow\VRChat\VRC ...
- Python上下文管理使用
import contextlib from queue import Queue @contextlib.contextmanager def myOpen(file): f = open(file ...