题目背景

勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利。但是,小L对数据结构的掌握实在十分渣渣。

所以,小L当时卡在了二叉树。

题目描述

在计算机科学中,二叉树是每个结点最多有两个子结点的有序树。通常子结点被称作“左孩子”和“右孩子”。二叉树被用作二叉搜索树和二叉堆。随后他又和他人讨论起了二叉搜索树。什么是二叉搜索树呢?二叉搜索树首先是一棵二叉树。设key[p]表示结点p上的数值。对于其中的每个结点p,若其存在左孩子lch,则key[p]>key[lch];若其存在右孩子rch,则key[p]<key[rch];注意,本题中的二叉搜索树应满足对于所有结点,其左子树中的key小于当前结点的key,其右子树中的key大于当前结点的key。(因为小L十分喜欢装xx,所以这里他十分装xx的给大家介绍了什么是二叉树和二叉搜索树)。

可是善于思考的小L不甘于只学习这些基础的东西。他思考了这样一个问题:现在给定一棵二叉树,可以任意修改结点的数值。修改一个结点的数值算作一次修改,且这个结点不能再被修改。若要将其变成一棵二叉搜索树,且任意时刻结点的数值必须是整数(可以是负整数或0),所要的最少修改次数。

这一定难不倒聪明的你吧!如果你能帮小L解决这个问题,也许他会把最后的资产分给你1/16哦!

输入输出格式

输入格式:

第一行一个正整数n表示二叉树节点数。

第二行n个正整数用空格分隔开,第i个数ai表示结点i的原始数值。

此后n - 1行每行两个非负整数fa, ch,第i + 2行描述结点i + 1的父亲编号fa,以及父子关系ch,(ch = 0 表示i + 1为左儿子,ch = 1表示i + 1为右儿子)。

为了让你稍微减轻些负担,小L规定:结点1一定是二叉树的根哦!

输出格式:

仅一行包含一个整数,表示最少的修改次数

输入输出样例

输入样例#1:

3
2 2 2
1 0
1 1

输出样例#1:

2

说明

20 % :n <= 10 , ai <= 100.

40 % :n <= 100 , ai <= 200

60 % :n <= 2000 .

100 % :n <= 10 ^ 5 ,  ai < 2 ^ 31.


没想出来,参考几年前一道模拟题

左中右,不就是中序遍历嘛

求一下中序遍历,再在这上面求LIS,n-LIS不就是答案嘛

但是有一个问题,2,1,3,这样的不能一次得到答案,因为必须严格单增

所以又用到了a[i]-i变为不严格单增

//
//  main.cpp
//  luogu9.1
//
//  Created by Candy on 9/17/16.
//  Copyright © 2016 Candy. All rights reserved.
//

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1e5+5,INF=2147483647;
int read(){char c=getchar();int x=0,f=1;while(c<'0'||c>'9'){if(c=='-')f=-1; c=getchar();}while(c>='0'&&c<='9'){x=x*10+c-'0'; c=getchar();}return x*f;
}
int n,a[N],fa,ch;
struct node{int ch[2],a;
}t[N];
int cnt=0;
void inOrder(int u){if(t[u].ch[0]) inOrder(t[u].ch[0]);a[++cnt]=t[u].a-cnt;if(t[u].ch[1]) inOrder(t[u].ch[1]);
}
int g[N],d[N],ans=0;
void lis(){for(int i=1;i<=n;i++) g[i]=INF;for(int i=1;i<=n;i++){int k=lower_bound(g+1,g+1+n,a[i])-g;d[i]=k;g[k]=a[i];ans=max(ans,d[i]);}
}
int main(int argc, const char * argv[]) {n=read();for(int i=1;i<=n;i++) t[i].a=read();for(int i=2;i<=n;i++){fa=read();ch=read();t[fa].ch[ch]=i;}inOrder(1);
//    for(int i=1;i<=n;i++) printf("%d ",a[i]);
    lis();printf("%d",n-ans);return 0;
}

洛谷U4727小L的二叉树[树转序列 LIS]相关推荐

  1. 信息学奥赛一本通 1365:FBI树(fbi) | 1928:【04NOIP普及组】FBI树 | 洛谷 P1087 [NOIP2004 普及组] FBI 树

    [题目链接] ybt 1365:FBI树(fbi) ybt 1928:[04NOIP普及组]FBI树 洛谷 P1087 [NOIP2004 普及组] FBI 树 [题目考点] 1. 二叉树 [解题思路 ...

  2. 洛谷 P3373 【模板】线段树 2 题解

    洛谷 P3373 [模板]线段树 2 题解 题面 题目链接:[戳这里](https://www.luogu.org/problemnew/show/P3373) 题目描述 输入输出格式 输入输出样例 ...

  3. 【NOIP模拟题】【DP】【LIS】【中缀表达式】2016.11.15 第一题 小L的二叉树 题解

    小L的二叉树 小L的二叉树 题目背景 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣. 所以,小L当时卡在了二叉树. [题目描述] 在计算机科学中,二 ...

  4. 洛谷 P4430 小猴打架

    洛谷 P4430 小猴打架 题目描述 一开始森林里面有N只互不相识的小猴子,它们经常打架,但打架的双方都必须不是好朋友.每次打完架后,打架的双方以及它们的好朋友就会互相认识,成为好朋友.经过N-1次打 ...

  5. 2017提高组D1T1 洛谷P3951 小凯的疑惑

    洛谷P3951 小凯的疑惑 原题 题目描述 小凯手中有两种面值的金币,两种面值均为正整数且彼此互素.每种金币小凯都有 无数个.在不找零的情况下,仅凭这两种金币,有些物品他是无法准确支付的.现在小 凯想 ...

  6. 洛谷 P2186 小Z的栈函数

    洛谷 P2186 小Z的栈函数 题目 题目描述 小Z最近发现了一个神奇的机器,这个机器的所有操作都是通过维护一个栈来完成的,它支持如下11个操作: NUM X:栈顶放入X. POP:抛弃栈顶元素. I ...

  7. (最小割)洛谷P1361 小M的作物

    洛谷P1361 小M的作物 思路: 这是一个两者取一的模型,将点集一分为二. 最小割在数值上等同于最大流.割去权值和最小的边,使图分成两部分,割下来的边权值和为最小割. 对于此题,先不考虑种在一起的情 ...

  8. 【01背包求方案数模板】洛谷 P1164 小A点菜

    洛谷 P1164 小A点菜 https://www.luogu.org/problemnew/show/P1164 题目背景 uim神犇拿到了uoi的ra(镭牌)后,立刻拉着基友小A到了一家--餐馆, ...

  9. 洛谷[P1120 小木棍]

    洛谷[P1120 小木棍] 题目: 思路: 枚举小木棒可能的长度,从数组最大值开始枚举,这个值能被总长度整除才是可行的 在使用dfs枚举小木棒的每一种可能,如果不可能就找下一个可能的长度开始枚举 注意 ...

最新文章

  1. 三星又推出新工具啦!Gear VR 可以兼容多个视频
  2. TPS(薄板样条) 2D 插值
  3. TAdoquery的Filter
  4. 哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之中——实际应用
  5. sql server模糊查询、分组
  6. springmvc知识点
  7. 【我的物联网成长记11】8招带你玩转规则引擎
  8. 三星开源的 tcpflow 抓包工具
  9. 恭喜51CTO视频课程认证讲师、博主李海园喜得姐妹花
  10. Java方法区和运行时常量池溢出问题分析(转)
  11. python从入门到精通 pdf 完整超清版-Python从入门到精通PDF高清完整版免费下载|百度云盘...
  12. 产品体验报告-美团APP
  13. 推荐方法-1:UserCFItemCF
  14. Visio2016卸载干净,以及同时安装Office2016和Visio2016的方法
  15. 烽火路由路虚拟服务器,netcore路由设置烽火
  16. win10系统还原和重装系统一样吗?win10系统还原怎么操作?
  17. Android传感器之光线传感器介绍
  18. 微信第三方平台的开发过程一
  19. rx6800s什么水平N卡 rx6800s什么水平
  20. 中层管理者如何提高管理能力?

热门文章

  1. 最新 Windows 7 7100安装
  2. 用户模式 linux救援单用户 虚拟机克隆和linux相互登陆
  3. Robots.txt - 禁止爬虫(转)
  4. 安装grid后启动asm报ORA-15149错误
  5. MFC中的MainFrame Dlg,App,Doc,View的关系
  6. 5G NR — 国内运营商的频段和带宽划分
  7. 互联网协议 — HTTP/3 超文本传输协议第 3 版
  8. Simulink仿真教程1---一个简单的仿真例子
  9. ARM处理器的运行模式和ARM寄存器
  10. 34.3. output