博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数组变树练习题
阅读量:4071 次
发布时间:2019-05-25

本文共 891 字,大约阅读时间需要 2 分钟。

传送门: 购买视频请输入优惠码  AdVHxHT 可优惠10元

题目描述 

对于一个没有重复元素的整数数组,请用其中元素构造一棵MaxTree,MaxTree定义为一棵二叉树,其中的节点与数组元素一一对应,同时对于MaxTree的每棵子树,它的根的元素值为子树的最大值。现有一建树方法,对于数组中的每个元素,其在树中的父亲为数组中它左边比它大的第一个数和右边比它大的第一个数中更小的一个。若两边都不存在比它大的数,那么它就是树根。请设计O(n)的算法实现这个方法。

给定一个无重复元素的数组A和它的大小n,请返回一个数组,其中每个元素为原数组中对应位置元素在树中的父亲节点的编号,若为根则值为-1。

测试样例:
[3,1,4,2],4
返回:[2,0,-1,2]
AC 代码

class MaxTree {public:    vector
buildMaxTree(vector
arr, int n) { vector
leftMax(n),rightMin(n); stack
s; for (int i=0; i
=0; --i) { while (!s.empty()&&arr[s.top()]<=arr[i]) { s.pop(); } if(s.empty()) rightMin[i] = -1; else rightMin[i] = s.top(); s.push(i); } for (int i=0; i
arr[rightMin[i]]) leftMax[i] = rightMin[i]; } } return leftMax; }};

转载地址:http://qhhji.baihongyu.com/

你可能感兴趣的文章
堆排序完整版,含注释
查看>>
二叉树深度优先遍历和广度优先遍历
查看>>
生产者消费者模型,循环队列实现
查看>>
PostgreSQL代码分析,查询优化部分,process_duplicate_ors
查看>>
PostgreSQL代码分析,查询优化部分,canonicalize_qual
查看>>
PostgreSQL代码分析,查询优化部分,pull_ands()和pull_ors()
查看>>
ORACLE权限管理调研笔记
查看>>
移进规约冲突一例
查看>>
IA32时钟周期的一些内容
查看>>
SM2椭圆曲线公钥密码算法
查看>>
获得github工程中的一个文件夹的方法
查看>>
《PostgreSQL技术内幕:查询优化深度探索》养成记
查看>>
PostgreSQL查询优化器详解之逻辑优化篇
查看>>
STM32中assert_param的使用
查看>>
C语言中的 (void*)0 与 (void)0
查看>>
vu 是什么
查看>>
io口的作用
查看>>
IO口的作用
查看>>
UIView的使用setNeedsDisplay
查看>>
归档与解归档
查看>>