1.改造二叉树

【题目描述】

小Y在学树论时看到了有关二叉树的介绍:在计算机科学中,二叉树是每个结点最多有两个子结点的有序树。通常子结点被称作“左孩子”和“右孩子”。二叉树被用作二叉搜索树和二叉堆。随后他又和他人讨论起了二叉搜索树。

什么是二叉搜索树呢?二叉搜索树首先是一棵二叉树。设key[p]表示结点p上的数值。对于其中的每个结点p,若其存在左孩子lch,则key[p]>key[lch];若其存在右孩子rch,则key[p]<key[rch];注意,本题中的二叉搜索树应满足对于所有结点,其左子树中的key小于当前结点的key,其右子树中的key大于当前结点的key。

小Y与他人讨论的内容则是,现在给定一棵二叉树,可以任意修改结点的数值。修改一个结点的数值算作一次修改,且这个结点不能再被修改。若要将其变成一棵二叉搜索树,且任意时刻结点的数值必须是整数(可以是负整数或0),所要的最少修改次数。

相信这一定难不倒你!请帮助小Y解决这个问题吧。

【输入格式】

第一行一个正整数n表示二叉树结点数。结点从1~n进行编号。

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

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

结点1一定是二叉树的根。

【输出格式】

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

【样例输入】

3

2 2 2

1 0

1 1

【样例输出】

2

【数据范围】

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

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

60 % :n <= 2000 .

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

思路:

  把这棵二叉树中序遍历

  建立一个新的序列

  我们会发现答案就是序列长度减去里面最长上升子序列的长度

  但是

  我们接着又会发现

  里面会有错误的情况

  所以我们要把当前序列变成一个处理后的序列(a[i]-=i)

  然后跑一遍最长不下降子序列

  答案就是序列长度减去最长不下降序列长度

  但是我们又会发现数据范围是10^5

  最长不下降序列是n^2的会超时

  所以我们优化一下最长上升子序列的方法

  舍弃具体序列元素转为只求长度

  我们可以得出这样的方法:

int LIS()
{int num_lis=0,pos;lis[num_lis]=-0x7ffffff;for(int i=1;i<=n;i++){tree_1[i]-=i;if(tree_1[i]>=lis[num_lis]){lis[++num_lis]=tree_1[i];continue;}pos=upper_bound(lis+1,lis+num_lis+1,tree_1[i])-lis;lis[pos]=tree_1[i];}return num_lis;
}

  现在我们可以的很轻松的得出答案

  然后ac了

来,上代码:

#include<cstdio>
#include<algorithm>using namespace std;int n,ai[100005],if_Z,lc[100005],rc[100005],new_tree=0;
int tree_1[100005],lis[100005];char word;inline void read_int(int &now_001)
{now_001=0,if_Z=1;word=getchar();while(word<'0'||word>'9'){if(word=='-') if_Z=-1;word=getchar();}while(word<='9'&&word>='0'){now_001=now_001*10+(int)(word-'0');word=getchar();}now_001*=if_Z;
}void dfs(int now)
{/*if(now>n) return ;dfs(now*2),dfs(now*2+1);tree_1[++new_tree]=tree[now];*/if(lc[now]) dfs(lc[now]);tree_1[++new_tree]=ai[now];if(rc[now]) dfs(rc[now]);
}int LIS()
{int num_lis=0,pos;lis[num_lis]=-0x7ffffff;for(int i=1;i<=n;i++){tree_1[i]-=i;if(tree_1[i]>=lis[num_lis]){lis[++num_lis]=tree_1[i];continue;}pos=upper_bound(lis+1,lis+num_lis+1,tree_1[i])-lis;lis[pos]=tree_1[i];}return num_lis;
}int main()
{read_int(n);for(int i=1;i<=n;i++) read_int(ai[i]);int father,lor;for(int i=2;i<=n;i++){read_int(father),read_int(lor);//tree[father*2+lor]=ai[i];if(lor==0) lc[father]=i;else rc[father]=i;}dfs(1);int ans=n-LIS();printf("%d\n",ans);return 0;
}

转载于:https://www.cnblogs.com/IUUUUUUUskyyy/p/6065794.html

改造二叉树 (长乐一中模拟赛day2T1)相关推荐

  1. 数字对 (长乐一中模拟赛day2T2)

    2.数字对 [题目描述] 小H是个善于思考的学生,现在她又在思考一个有关序列的问题. 她的面前浮现出一个长度为n的序列{ai},她想找出一段区间[L, R](1 <= L <= R < ...

  2. 一中模拟赛3.15——树上gcd

    Solution 计算每个质因子在哪些点出现,然后在树上只保存这些点,通过计算大于000的g(i,j)g(i,j)g(i,j)个数来计算贡献 如果质因子次数>1>1>1,那么把p2p ...

  3. 2018.7.17 绍兴一中模拟赛 解题报告

    成绩: 100+100+50=250(考得不错,只可惜跑得太慢,是250中最慢的一个) T1:交换(swap) 满分解法1: 这题是真的水. 先介绍一个比较麻烦的做法,也是我考试时的做法. 大致思路就 ...

  4. 绍兴一中模拟赛3.19——时光流转

    Description Solution 离线以后点分 对于每个点,都用这个点的祖先把这个点的子树更新一遍, 考虑到操作时间早的才能更新晚的和题目中说的"路径上边权都大于等于 v a l v ...

  5. snoi 省选模拟赛day2t1 bzoj 2873: 光之大陆

    Description 在光之大陆的土地上,各种势力盘根错节.来自光之峡谷的精灵,来自黑暗森林的亡灵,来自古老东方的人类共同生活在一起.善于打造装置的矮人,善于发明的侏儒,隐匿于山林的巨人也坚守着属于 ...

  6. 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中

    题目名称 正确答案  序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...

  7. Java 第十一届 蓝桥杯 省模拟赛 第十层的二叉树

    一棵10层的二叉树,最多包含多少个结点? 注意当一棵二叉树只有一个结点时为一层. 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余 ...

  8. [noip模拟]改造二叉树LIS

    1.改造二叉树 [题目描述] 小Y在学树论时看到了有关二叉树的介绍:在计算机科学中,二叉树是每个结点最多有两个子结点的有序树.通常子结点被称作"左孩子"和"右孩子&quo ...

  9. NOI.AC NOIP模拟赛 第六场 游记

    NOI.AC NOIP模拟赛 第六场 游记 queen 题目大意: 在一个\(n\times n(n\le10^5)\)的棋盘上,放有\(m(m\le10^5)\)个皇后,其中每一个皇后都可以向上.下 ...

最新文章

  1. 如何解决用谷歌浏览器调试代码接口请求的时候,跳转网页切换网页的时候,上一个页面的接口请求记录被清除消失的问题
  2. Eclipse安装SVN最新版插件
  3. Java教程之JDBC中的常用接口和类
  4. 强化学习核心文章一百篇
  5. 四路由器的OSPF DR ,BDR
  6. 操作系统学习笔记-03-操作系统的发展和分类
  7. BZOJ2820:YY的GCD
  8. 移动端拖拽(模块化开发,触摸事件,webpack)
  9. MyEclipse设置文件默认打开方式
  10. 使用高效代理抓取58同城巴州二手房信息并保存至excel
  11. 图书管理系统C语言课程设计
  12. Linux的操作系统下载及安装
  13. 算法 第四版 2.1.25 不需要交换的插入排序
  14. libjpeg、libpng使用方法
  15. GTK-sopcast 0.2.8
  16. utf8编码在线转换html,utf8 gb2312编码在线转换工具
  17. LightBox -灯箱效果插件(非常漂亮) Jquery灯箱效果
  18. 怎么将照片尺寸调整成两寸?照片调整尺寸方法分享
  19. sql语句 查询表中 每门课都大于80分的学生名称 根据以下三种 学习sql 中其他函数的使用
  20. 抠图算法:经典的贝叶斯抠图

热门文章

  1. 【Python-3.5】绘制随机漫步图
  2. Mybatis自定义分布式二级缓存实现与遇到的一些问题解决方案!
  3. visual studio(vs)中项目解决方案的目录组织安排
  4. 安装WampServer时出现的问题(丢失VCRUNTIME140.dll或MSVCR110.dll)以及解决办法
  5. 异常概念和处理机制,try-catch-finally,throw和throws,自定义异常
  6. object references an unsaved transient instance - save the transient instance before flushing异常问题处理
  7. 在Swift中向数组添加元素
  8. 在Python中将列表转换为元组
  9. bootstrap table 光标_第三章之Bootstrap 表格与按钮功能
  10. 仿制波形驱动机器人- SAW