改造二叉树 (长乐一中模拟赛day2T1)
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)相关推荐
- 数字对 (长乐一中模拟赛day2T2)
2.数字对 [题目描述] 小H是个善于思考的学生,现在她又在思考一个有关序列的问题. 她的面前浮现出一个长度为n的序列{ai},她想找出一段区间[L, R](1 <= L <= R < ...
- 一中模拟赛3.15——树上gcd
Solution 计算每个质因子在哪些点出现,然后在树上只保存这些点,通过计算大于000的g(i,j)g(i,j)g(i,j)个数来计算贡献 如果质因子次数>1>1>1,那么把p2p ...
- 2018.7.17 绍兴一中模拟赛 解题报告
成绩: 100+100+50=250(考得不错,只可惜跑得太慢,是250中最慢的一个) T1:交换(swap) 满分解法1: 这题是真的水. 先介绍一个比较麻烦的做法,也是我考试时的做法. 大致思路就 ...
- 绍兴一中模拟赛3.19——时光流转
Description Solution 离线以后点分 对于每个点,都用这个点的祖先把这个点的子树更新一遍, 考虑到操作时间早的才能更新晚的和题目中说的"路径上边权都大于等于 v a l v ...
- snoi 省选模拟赛day2t1 bzoj 2873: 光之大陆
Description 在光之大陆的土地上,各种势力盘根错节.来自光之峡谷的精灵,来自黑暗森林的亡灵,来自古老东方的人类共同生活在一起.善于打造装置的矮人,善于发明的侏儒,隐匿于山林的巨人也坚守着属于 ...
- 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中
题目名称 正确答案 序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...
- Java 第十一届 蓝桥杯 省模拟赛 第十层的二叉树
一棵10层的二叉树,最多包含多少个结点? 注意当一棵二叉树只有一个结点时为一层. 答案提交 这是一道结果填空的题,你只需要算出结果后提交即可.本题的结果为一个整数,在提交答案时只填写这个整数,填写多余 ...
- [noip模拟]改造二叉树LIS
1.改造二叉树 [题目描述] 小Y在学树论时看到了有关二叉树的介绍:在计算机科学中,二叉树是每个结点最多有两个子结点的有序树.通常子结点被称作"左孩子"和"右孩子&quo ...
- NOI.AC NOIP模拟赛 第六场 游记
NOI.AC NOIP模拟赛 第六场 游记 queen 题目大意: 在一个\(n\times n(n\le10^5)\)的棋盘上,放有\(m(m\le10^5)\)个皇后,其中每一个皇后都可以向上.下 ...
最新文章
- 如何解决用谷歌浏览器调试代码接口请求的时候,跳转网页切换网页的时候,上一个页面的接口请求记录被清除消失的问题
- Eclipse安装SVN最新版插件
- Java教程之JDBC中的常用接口和类
- 强化学习核心文章一百篇
- 四路由器的OSPF DR ,BDR
- 操作系统学习笔记-03-操作系统的发展和分类
- BZOJ2820:YY的GCD
- 移动端拖拽(模块化开发,触摸事件,webpack)
- MyEclipse设置文件默认打开方式
- 使用高效代理抓取58同城巴州二手房信息并保存至excel
- 图书管理系统C语言课程设计
- Linux的操作系统下载及安装
- 算法 第四版 2.1.25 不需要交换的插入排序
- libjpeg、libpng使用方法
- GTK-sopcast 0.2.8
- utf8编码在线转换html,utf8 gb2312编码在线转换工具
- LightBox -灯箱效果插件(非常漂亮) Jquery灯箱效果
- 怎么将照片尺寸调整成两寸?照片调整尺寸方法分享
- sql语句 查询表中 每门课都大于80分的学生名称 根据以下三种 学习sql 中其他函数的使用
- 抠图算法:经典的贝叶斯抠图
热门文章
- 【Python-3.5】绘制随机漫步图
- Mybatis自定义分布式二级缓存实现与遇到的一些问题解决方案!
- visual studio(vs)中项目解决方案的目录组织安排
- 安装WampServer时出现的问题(丢失VCRUNTIME140.dll或MSVCR110.dll)以及解决办法
- 异常概念和处理机制,try-catch-finally,throw和throws,自定义异常
- object references an unsaved transient instance - save the transient instance before flushing异常问题处理
- 在Swift中向数组添加元素
- 在Python中将列表转换为元组
- bootstrap table 光标_第三章之Bootstrap 表格与按钮功能
- 仿制波形驱动机器人- SAW