【问题描述】
众所周知,zzh 和 heyi 是一对竹马竹马,他们从小一起学 C++,最后都成了著名的神犇。而时间回溯到他们童年,这天 zzh 邀请 heyi 来参加 zzh 举行的男性家庭聚会。
而 zzh 则在苦恼该邀请哪些人。
我们按照一定的顺序给家庭成员编号,为了表示尊敬,我们给辈分最大的人编号为
1。每个人都有一定的身价,为了避免尴尬,我们希望邀请的所有家庭成员中每个人的身价都必须要小于他的直系长辈,此时 zzh 想知道最多能邀请多少人。
注意:直系长辈只包含父亲祖父等,叔叔不算。
【输入格式】
输入文件名为 chikuma.in。
输入文件第一行为一个正整数 n。
接下来 n 行,每行两个非负整数vi,pi,表示 i 号成员的身价与父亲。
【输出格式】
输出文件名为 chikuma.out。
输出文件包含 1 行,一个正整数,表示最多能邀请的人数。
【输入输出样例】
chikuma.in
chikuma.out
6
3 0
1 1
2 1
3 1
4 1
5 1
5
【输入输出样例说明】
2~6 号家庭成员的直系长辈为 1 号家庭成员。
如果 zzh 不邀请 1 号家庭成员,那么 2~6 号家庭成员都能参加,能够邀请 5 个人。
如果 zzh 邀请 1 号家庭成员,那么由于 3 号、4 号和 5 号家庭成员身价不低于 1 号
家庭成员,将不能被邀请,因此能够邀请 3 个人。
因此,最多能邀请 5 个人。
【数据范围】
对于 10%的数据,n≤10。
对于 40%的数据,n≤1000。
另有 10%的数据,保证不存在有叔叔的情况
对于 100%的数据,n≤200000,0≤vi≤1e9,
1≤pi<i,p1=0。
【题解】
对于40分做法:设f[i][j]表示以i为根的子树中选出的人最大身价的人为j的时候最多选出几个人,转移很简单。
对于100分做法:

线段树合并

线段树中叶节点表示最大为该身价时可选人数,非叶节点维护最大值,答案即为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的更多相关文章

  1. [Swust OJ 772]--Friend(并查集+map的运用)

    题目链接:http://acm.swust.edu.cn/problem/772/ Time limit(ms): 1000 Memory limit(kb): 65535    Descriptio ...

  2. python --常用内置模块01

    1.简单了解模块         模块就是我们把装有特定功能的代码进行归类的解构,从代码编写的单位来看我们的程序 从小到大的顺序:一条代码< 语句块<代码块(函数,类) < 模块 我 ...

  3. qwq。。胡诌qwq

    1,十里寒塘,红楼灯火阑珊,晓风残月,思念醒了一半. 晨钟催落月,淑气催黄鸟,而花千树而你还未还,三月烟花,只剩远影孤帆,珠箔飘灯,大雁独自来返,柳絮铺地,桃花落了菀晚, 琴声弹起,雨落长安,长夜漫漫 ...

  4. 佛山6397.7539(薇)xiaojie:佛山哪里有xiaomei

    佛山哪里有小姐服务大保健[微信:6397.7539倩儿小妹[佛山叫小姐服务√o服务微信:6397.7539倩儿小妹[佛山叫小姐服务][十微信:6397.7539倩儿小妹][佛山叫小姐包夜服务][十微信 ...

  5. 宜宾1178.9873(薇)xiaojie:宜宾哪里有xiaomei

    宜宾哪里有小姐服务大保健[微信:1178.9873倩儿小妹[宜宾叫小姐服务√o服务微信:1178.9873倩儿小妹[宜宾叫小姐服务][十微信:1178.9873倩儿小妹][宜宾叫小姐包夜服务][十微信 ...

随机推荐

  1. H3C 寻找邻居

  2. v-for(:key)绑定index、id、key的区别

    Vue 2.0 v-for 响应式key, index及item.id参数对v-bind:key值造成差异研究 在github上阅览README.md以获得最佳阅读体验,点这里 v-for响应式key ...

  3. React 简书

    create-react-app   jianshu yarn add styled-components -D       利用js写css样式  样式会更高效 https://github.com ...

  4. H3C 基本的局域网间路由

  5. 【t050】方程求解

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] 要求Xi(i = 1,2,3,4)是一个[-T..T]中的整数,满足方程AX1 + BX2 + CX3 ...

  6. Oracle 和pl/sql以及pl/sql developer

    oracle是厂家的名字,也是数据库产品的名字.比如sybase公司的sybase数据库.而微软公司的数据库产品就叫sqlserver了. pl/sql 是oracle数据库所用的sql语言的名称.微 ...

  7. Codeforces 293E 点分治+cdq

    Codeforces 293E 传送门:https://codeforces.com/contest/293/problem/E 题意: 给你一颗边权一开始为0的树,然后给你n-1次操作,每次给边加上 ...

  8. TextInputLayout低版本bug :“android.view.InflateException: Binary XML file line #6 : Error inflating class Textview”

    开发中用到TextInputLayout配合TextInputEdittext做输入框,在android7.0 android8.0手机上运行正常,在异步android5.0.2的手机上,点击输入框就 ...

  9. Perl 的内置变量$|

    $|是perl的内置变量,默认情况下是0,如果设置为非0的话,表示当前的输出不经过缓存立刻输出.相当于c语言的fflush()函数,立即刷新缓冲区. 比如你print或者write一个文件,实际是需要 ...

  10. 简易数据分析 15 | Web Scraper 高级用法——CSS 选择器的使用

    这是简易数据分析系列的第 15 篇文章. 年末事情比较忙,很久不更新了,后台一直有读者催更,我看了一些读者给我的私信,发现一些通用的问题,所以单独写篇文章,介绍一些 Web Scraper 的进阶用法 ...