算法总结之 构造数组MaxTree
一个数组的MaxTree定义如下:
数组必须没有重复元素
MaxTree是一颗二叉树,数组的每一个值对应一个二叉树的节点
包括MaxTre树在内且在其中的每一颗子树上,值最大的节点都是树的头
给定一个 没有重复元素的数组arr,写出生成这个数组的MaxTree的函数,要求如果数组长度为N, 时间复杂度O(N) 额外空间复杂度O(N)
思路 :
找到每个数的 左边第一个比它小的数 右边第一个比它大的数
如何找到呢?
利用栈 !!!
构造MaxTree算法解析
本文介绍了一种构造MaxTree的算法,该算法能在O(N)的时间复杂度内完成任务,同时保证额外空间复杂度为O(N)。文章详细阐述了通过使用栈来找到每个数左侧第一个较小值和右侧第一个较大值的方法。
一个数组的MaxTree定义如下:
数组必须没有重复元素
MaxTree是一颗二叉树,数组的每一个值对应一个二叉树的节点
包括MaxTre树在内且在其中的每一颗子树上,值最大的节点都是树的头
给定一个 没有重复元素的数组arr,写出生成这个数组的MaxTree的函数,要求如果数组长度为N, 时间复杂度O(N) 额外空间复杂度O(N)
思路 :
找到每个数的 左边第一个比它小的数 右边第一个比它大的数
如何找到呢?
利用栈 !!!
580

被折叠的 条评论
为什么被折叠?