leetcode-14-basic-breadthFirstSearch
BFS: breadth first search
107. Binary Tree Level Order Traversal II
解题思路:
本来我是用map<int,int>存所有节点的值和深度(root是0),然后遍历map,result[depth].push_back(val)。但是因为map是无序的,所以
插入的时候,result[i]里元素的顺序会有问题,比如
后面改用下面的方法。先计算树的最大深度,然后遍历树的时候直接插入。后面自己写了个测试,有点丑(微笑脸)。
#include <iostream>
#include <cmath>
#include <vector>
#include <ctime>
#include <time.h>
#include <stdlib.h>
#include <map>
#include <algorithm>
using namespace std; struct TreeNode {
int val;
TreeNode *left;
TreeNode *right;
TreeNode(int x) : val(x), left(NULL), right(NULL) {}
}; class Solution {
public:
// if leaf node, depth=1
int Depth(TreeNode* root) {
if (!root)
return 0;
return max(Depth(root->left), Depth(root->right)) + 1;
}
void make(TreeNode* root, int depth, vector<vector<int> >& result) {
if (!root)
return;
// insert
result[depth].push_back(root->val);
make(root->left, depth-1, result);
make(root->right, depth-1, result);
}
vector<vector<int> > levelOrderBottom(TreeNode* root) {
int depth = Depth(root);
// result needs initialization
vector<vector<int> > result(depth, vector<int> {});
make(root, depth-1, result);
return result;
} }; int main() {
Solution s;
TreeNode temp(3);
TreeNode* root = &temp;
TreeNode a(9);
root->left = &a;
TreeNode b(20);
root->right = &b;
TreeNode c(15);
root->right->left = &c;
TreeNode d(7);
root->right->right = &d;
vector<vector<int> > re = s.levelOrderBottom(root);
// cout << re.empty();
vector<vector<int> >::iterator it1;
vector<int>::iterator it2;
for (it1 = re.begin(); it1 != re.end(); it1++) {
cout << "*" << " ";
for (it2 = it1->begin(); it2 != it1->end(); it2++)
cout << *it2 << " ";
cout << endl;
}
return 0;
}
类似的题目有:
102. Binary Tree Level Order Traversal
Given a binary tree, return the level order traversal of its nodes' values. (ie, from left to right, level by level).
解题思路:
这个是要正序输出,那么只要改动make中
make(root->left, depth+1, result);
make(root->right, depth+1, result);
改动levelOrder中
make(root, 0, result);
即可。
类似的还有:
515. Find Largest Value in Each Tree Row
解题思路:可以用上面的方法找每行的元素,然后取最大值就可以了。不过比较慢。
改进了一下,只存最大值就好了。需要注意的是,测试用例中有负数。。不只是int型,所以用一个超小值做初始值。
vector<int> largestValues(TreeNode* root) {
vector<int> result2;
if (!root)
return result2;
int depth = Depth(root);
int size = depth;
// result needs initialization
vector<int> result(depth, -2147483648);
make(root, 0, result);
return result;
}
// if leaf node, depth=1
int Depth(TreeNode* root) {
if (!root)
return 0;
return max(Depth(root->left), Depth(root->right)) + 1;
}
void make(TreeNode* root, int depth, vector<int>& result) {
if (!root)
return;
if (root->val > result[depth])
result[depth] = root->val;
make(root->left, depth+1, result);
make(root->right, depth+1, result);
}
好吧,类似的还有这道:
513. Find Bottom Left Tree Value
解题思路:
仍然是复用上面的代码,改
return result[result.size()-1][0];
不过显然这样效率很低。我想的改进是,增加一个记录树深度的变量d,在make函数中,push_back后增加一个判断,
如果已经到了最后一层,就终止,不再压后面的栈。这样的话,时间从22s->12s。
if (depth == d-1)
return;
leetcode-14-basic-breadthFirstSearch的更多相关文章
- [LeetCode] 224. Basic Calculator 基本计算器
Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...
- [LeetCode] 227. Basic Calculator II 基本计算器 II
Implement a basic calculator to evaluate a simple expression string. The expression string contains ...
- [LeetCode] 772. Basic Calculator III 基本计算器之三
Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...
- [LeetCode] 227. Basic Calculator II 基本计算器之二
Implement a basic calculator to evaluate a simple expression string. The expression string contains ...
- [LeetCode] 14. Longest Common Prefix 最长共同前缀
Write a function to find the longest common prefix string amongst an array of strings. If there is n ...
- LeetCode 14. 最长公共前缀(Longest Common Prefix)
14. 最长公共前缀 14. Longest Common Prefix 题目描述 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". Lee ...
- 【leetcode】Basic Calculator III
题目如下: Implement a basic calculator to evaluate a simple expression string. The expression string may ...
- Java实现 LeetCode 14 最长公共前缀
14. 最长公共前缀 编写一个函数来查找字符串数组中的最长公共前缀. 如果不存在公共前缀,返回空字符串 "". 示例 1: 输入: ["flower",&quo ...
- LeetCode#227.Basic Calculator II
题目 Implement a basic calculator to evaluate a simple expression string. The expression string contai ...
- Java for LeetCode 227 Basic Calculator II
Implement a basic calculator to evaluate a simple expression string. The expression string contains ...
随机推荐
- NET?.NET Framework?.NET Core?
什么是.NET?什么是.NET Framework?什么是.NET Core? https://www.cnblogs.com/1996V/p/9037603.html 什么是.NET?什么是.NET ...
- docker 在Windows下使用遇到的坑
1.大部分系统不支持直接安装docker for windows,只能使用docker toolbox,相当于在Windows上安装了一个linux的虚拟机 2.启动docker toolbox的时候 ...
- (转)关于inode和block的两道企业面试题
关于inode和block的两道企业面试题 原文:http://www.tk4479.net/xiaolong361/article/details/52373374 一.一个100M的磁盘分区,分别 ...
- MapReduce基本流程与设计思想初步
1.MapReduce是什么? MapReduce是一种编程模型,用于大规模数据集的并行运算.它借用了函数式的编程概念,是Google发明的一种数据处理模型. 主要思想为:Map(映射)和Reduce ...
- IQueryable和IEnumerable的区别
- (译)Cg Programming/Unity(Cg编程/Unity)
最近在学习Unity3d中的shader编程,能找到的中文资料比较少,于是,尝试翻译一下wiki Books上的资料,以方便其他跟我一样的入门学习者.由于是第一次翻译技术资料,经验不足,难免出错,请路 ...
- windows下vue-cli及webpack 构建网站(一)环境安装
1.安装Node.js,node.js安装包及源码下载地址为:https://nodejs.org/en/download/. 2.安装npm,由于新版的nodejs已经集成了npm,所以之前npm也 ...
- Godaddy虚拟主机新建mysql数据库 2019最新
第一次用狗爹,完全摸不着路子. 网站本地已搭建,不知道数据库是在哪里上传. 百度搜索结果都是四五年前的旧内容,耽误时间. 还是问客服,Godaddy的客服确实不赖 godaddy虚拟主机如何新建数据库 ...
- RSA加密解密(转)
RSA加密解密 对于RSA产生的公钥.私钥,我们可以有两种方式可以对信息进行加密解密.私钥加密-公钥解密 和 公钥加密-私钥解密RSA公钥加密算法是1977年由罗纳德·李维斯特(Ron Rivest) ...
- kmem_alloc
http://www.lehman.cuny.edu/cgi-bin/man-cgi?kmem_alloc+9