左神算法书籍《程序员代码面试指南》——1_08构造数组的MaxTree
【题目】
将一个没有重复数字的数组中的数据构造一个二叉树
每个节点都是该子树的最大值
【要求】
时间复杂度为O(N)
【题解】
使用单调栈,栈的顺序是维持从大到小排序
通过使用单调栈,将数组中中所有数的左右比他大的数记录下来
当某个数既无左边比他大的数,有无右边比他大的数,则该数为全局最大,将其作为二叉树的根
然后,某数只有左比他大的数,或者右比他大的数,则该数直接挂在比他大的数的下面,
当某个数既有左比他大的数,又有右比他大的数,则挂在两个数中较小数的下面。
然后直接构成一棵树。
#include <iostream>
#include <vector>
#include <deque>
#include <sstream> using namespace std; struct Node
{
int val;
Node* lchild;
Node* rchild;
Node(int a) :val(a), lchild(nullptr), rchild(nullptr) {}
}; void creatMaxTree(Node*& root, vector<int>v)
{//以下代码都是以数组的下角标为根据
vector<Node*>node;
vector<pair<int, int>>res;//存储每个数的左右大小的数
res.resize(v.size());
deque<int>d;//单调栈
for (int i = ; i < v.size(); ++i)
{
Node* p = new Node(v[i]);
node.push_back(p);//先生成相关的节点
while (!d.empty() && v[i] > v[d.back()])
{
int index = d.back();
d.pop_back();
if (d.empty())//有右大值,无左大值
res[index] = pair<int, int>(-, i);
else//有右大值和左大值
res[index] = pair<int, int>(d.back(), i);
}
d.push_back(i);
}
while (!d.empty())
{
int index = d.back();
d.pop_back();
if (d.empty())//即无右大值,又无左大值
res[index] = pair<int, int>(-, -);
else//无右大值有左大值
res[index] = pair<int, int>(d.back(), -);
}
for (int i = ; i < res.size(); ++i)
{
int a, b;
a = res[i].first;
b = res[i].second;
if (a == - && b == -)//即无右大值,又无左大值为根节点
root = node[i];
else if (a == - && b != -)
node[b]->rchild = node[i];
else if (a != - && b == -)
node[a]->lchild = node[i];
else if (v[a] > v[b])
node[b]->rchild = node[i];
else
node[a]->lchild = node[i];
}
} //打印树形状进行查看
class PrintTree
{
public:
void Print(Node* root)
{
cout << "The shape of tree is: " << endl;
cout << "=============================================================" << endl;
PrintShape(root, , "H", );
cout << "=============================================================" << endl;
}
void PrintShape(Node* root, int h, string c, int len)
{
if (root)
{
PrintShape(root->rchild, h + , "v", len);
string val;
stringstream ss;
ss << root->val;
ss >> val;
val = c + val + c;
int lenM = val.length();
int lenL = (len - lenM) / ;
int lenR = len - lenM - lenL;
val = getSpace(lenL) + val + getSpace(lenR);
cout << getSpace(h*len) + val << endl;
PrintShape(root->lchild, h + , "^", len);
} }
string getSpace(int num)
{
string space = " ";
for (int i = ; i < num; ++i)
space.append(" ");
return space;
}
}; void Test()
{
vector<int>v;
v = { ,,,,, };
Node* root = nullptr;
creatMaxTree(root, v);
PrintTree print;
print.Print(root);
}
左神算法书籍《程序员代码面试指南》——1_08构造数组的MaxTree的更多相关文章
- 程序员代码面试指南 IT名企算法与数据结构题目最优解
原文链接 这是一本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现.针对当前程序员面试缺乏权威题目汇总这一痛点,本书选取将近200道真实出现过的经典代码面试题,帮 ...
- 《程序员代码面试指南》第一章 栈和队列 构造数组的MaxTree
题目 给出一个无重复元素的数组,构造此数组的MaxTree, java代码 /** * @Description: 构造数组的MaxTree * @Author: lizhouwei * @Creat ...
- 程序员代码面试指南:IT名企算法与数据结构题目最优解
第1章栈和队列 1设计一个有getMin功能的栈(士★☆☆☆) 1由两个栈组成的队列(尉★★☆☆) 5如何仅用递归函数和栈操作逆序一个栈(尉★★☆☆) 8猫狗队列(士★☆☆☆)10用一个栈实现另一 ...
- 左神算法书籍《程序员代码面试指南》——3_05Morris遍历二叉树的神级方法【★★★★★】
[问题]介绍一种时间复杂度O(N),额外空间复杂度O(1)的二叉树的遍历方式,N为二叉树的节点个数无论是递归还是非递归,避免不了额外空间为O(h),h 为二叉树的高度使用morris遍历,即利用空节点 ...
- 左神算法书籍《程序员代码面试指南》——2_11将单链表的每K个节点之间逆序
[题目]给定一个单链表的头节点head,实现一个调整单链表的函数,使得每K个节点之间逆序,如果最后不够K个节点一组,则不调整最后几个节点.例如:链表:1->2->3->4->5 ...
- 左神算法书籍《程序员代码面试指南》——1_01设计一个有getMin功能的栈
[题目] 实现一个特殊的栈,在实现栈的基本功能的基础上,再实现返回栈中最小元素的操作. [要求] 1.pop.push.getMin操作的时间复杂度都是O(1).2.设计的栈类型可以使用现成的栈结构. ...
- 左神算法书籍《程序员代码面试指南》——2_03删除链表的中间节点和a/b处的节点
[题目]给定链表的头节点head,实现删除链表的中间节点的函数.例如:不删除任何节点:1->2,删除节点1:1->2->3,删除节点2:1->2->3->4,删除节 ...
- 左神算法书籍《程序员代码面试指南》——2_02在单链表和双链表中删除倒数第k个字节
[题目]分别实现两个函数,一个可以删除单链表中倒数第K个节点,另一个可以删除双链表中倒数第K个节点.[要求]如果链表长度为N,时间复杂度达到O(N),额外空间复杂度达到O(1).[题解]从头遍历链表, ...
- 左神算法书籍《程序员代码面试指南》——1_10最大值减去最小值小于或等于num的子数组数量
[题目]给定数组arr和整数num,共返回有多少个子数组满足如下情况:max(arr[i.j]) - min(arr[i.j]) <= num max(arfi.j])表示子数组ar[ij]中的 ...
随机推荐
- 旋转矩形碰撞检测 OBB方向包围盒算法
在cocos2dx中进行矩形的碰撞检测时需要对旋转过的矩形做碰撞检查,由于游戏没有使用Box2D等物理引擎,所以采用了OBB(Oriented bounding box)方向包围盒算法,这个算法是基于 ...
- MySQL初始化(35-03)
1, 在MySQL的安装目录下新建个data目录. 2,初始化mysqld --initialize-insecure
- Static 关键字的 5 种用法,你会几种?
); System.out.println(Thread.currentThread().getName() ...
- POJ 3376 Finding Palindromes EX-KMP+字典树
题意: 给你n个串串,每个串串可以选择和n个字符串拼接(可以自己和自己拼接),问有多少个拼接后的字符串是回文. 所有的串串长度不超过2e6: 题解: 这题由于是在POJ上,所以string也用不了,会 ...
- 面试系列12 redis和memcached有什么区别
(1)redis和memcached有啥区别 这个事儿吧,你可以比较出N多个区别来,但是我还是采取redis作者给出的几个比较吧 1)Redis支持服务器端的数据操作:Redis相比Memcached ...
- SUMMARY | JAVA中的数据结构
String String类是不可修改的,创建需要修改的字符串需要使用StringBuffer(线程同步,安全性更高)或者StringBuilder(线程非同步,速度更快). 可以用“+”连接Stri ...
- ES6和常用特性归纳
ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了.Mozilla公司将在这个标准的基础上,推出JavaScript 2.0. ECMAS ...
- openSUSE 安装compass,mkmf.rb can't find,checking for ffi.h...extconf.rb failed
安装compass时,提示 Fetching: sass-.gem (%) Successfully installed sass- Fetching: ffi-.gem (%) Building n ...
- CSS3 学习笔记(边框 背景 字体 图片 旋转等)
边框 盒子圆角 border-radius:5px / 20%: border-radius:5px 4px 3px 2px; 左上,右上,右下,左下 盒子阴影 box-shadow:box-shad ...
- 8年前诞生于淘宝,细数阿里云RPA 的前世今生!
9月10日,踏入55岁的马云正式卸任阿里巴巴董事局主席一职,由阿里巴巴集团CEO张勇接任.公寓创业.西湖论剑.美国敲钟,从成立到登顶中国最值钱的公司,阿里巴巴只用了20年. 阿里云RPA,2011年诞 ...