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 Core 2.1 Global Tools
微软工程师Nate McMaster的博文.NET Core 2.1 Global Tools https://natemcmaster.com/blog/2018/05/12/dotnet-glob ...
- MapReduce编程入门实例之WordCount:分别在Eclipse和Hadoop集群上运行
上一篇博文如何在Eclipse下搭建Hadoop开发环境,今天给大家介绍一下如何分别分别在Eclipse和Hadoop集群上运行我们的MapReduce程序! 1. 在Eclipse环境下运行MapR ...
- 《springcloud 二》微服务动态网关,网关集群
动态网关 实际上是网关和分布式配置中心的整合,通过post手动刷新,生效 动态网关 传统方式将路由规则配置在配置文件中,如果路由规则发生了改变,需要重启服务器.结合整合SpringCloud C ...
- (转)在Unity3D中控制动画播放
用Unity3D也算是好久了,但是每次做项目总还是能学到新的东西.这次做一个TPS的项目就遇到了这样一个问题,如何同时在上下半身播放不同的动画?解决方法其实是很简单,但由于对于动画资源的了解不足导致问 ...
- Spring Boot自动配置原理与实践(一)
前言 Spring Boot众所周知是为了简化Spring的配置,省去XML的复杂化配置(虽然Spring官方推荐也使用Java配置)采用Java+Annotation方式配置.如下几个问题是我刚开始 ...
- Vue.js之vue-router路由
vue学习的一系列,全部来自于表哥---表严肃,是我遇到过的讲课最通透,英文发音最好听的老师,想一起听课就去这里吧 https://biaoyansu.com/i/hzhj1206 1概述 vue-r ...
- 常用API(Object、String、StringBuffer、用户登陆注册)
常用API 今日内容介绍 u Object u String u StringBuilder 第1章 Java的API及Object类 在以前的学习过程中,我们都在学习对象基本特征.对象的使用以及对象 ...
- MyBatis关联查询、多条件查询
MyBatis关联查询.多条件查询 1.一对一查询 任务需求; 根据班级的信息查询出教师的相关信息 1.数据库表的设计 班级表: 教师表: 2.实体类的设计 班级表: public class Cla ...
- 使用jQuery发送ajax
我们先看一下js的原生ajax 直接进入代码,我们先准备好servlet,之后不会改动,所以先看一下. package cn.curry.servlet; import com.alibaba.fas ...
- JavaScript_11_验证
表单验证: JavaScript可用来在数据被送往服务器前对HTML表单中的输入数据进行验证 1. 是否填写了必填项目 2. 邮件地址是否合法 ... <form action="su ...