[Leetcode]111. Minimum Depth of Binary Tree
2016-07-11 17:44
302 查看
Given a binary tree, find its minimum depth.
The minimum depth is the number of nodes along the shortest path from the root node down to the nearest leaf node.
递归:时间复杂度O(n),空间复杂度O(logn).
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
int minDepth(TreeNode* root) {
return minDepth(root, false);
}
private:
static int minDepth(const TreeNode* root, bool hasbrother) {
if (!root)
return hasbrother? INT_MAX : 0;
return 1 + min(minDepth(root->left, root->right != nullptr), minDepth(root->right, root->left != nullptr));
}
};迭代:时间复杂度O(n),空间复杂度O(logn)。
class Solution {
public:
int minDepth(TreeNode* root) {
if (root == nullptr)
return 0;
int result = INT_MAX;
stack<pair<TreeNode*, int>> s;
s.push(make_pair(root, 1));
while (!s.empty()) {
auto node = s.top().first;
auto depth = s.top().second;
s.pop();
if (node->left == nullptr && node->right == nullptr)
result = min(result, depth);
if (node->left && result > depth)
s.push(make_pair(node->left, depth + 1));
if (node->right && result > depth)
s.push(make_pair(node->right, depth + 1));
}
return result;
}
};
The minimum depth is the number of nodes along the shortest path from the root node down to the nearest leaf node.
递归:时间复杂度O(n),空间复杂度O(logn).
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
int minDepth(TreeNode* root) {
return minDepth(root, false);
}
private:
static int minDepth(const TreeNode* root, bool hasbrother) {
if (!root)
return hasbrother? INT_MAX : 0;
return 1 + min(minDepth(root->left, root->right != nullptr), minDepth(root->right, root->left != nullptr));
}
};迭代:时间复杂度O(n),空间复杂度O(logn)。
class Solution {
public:
int minDepth(TreeNode* root) {
if (root == nullptr)
return 0;
int result = INT_MAX;
stack<pair<TreeNode*, int>> s;
s.push(make_pair(root, 1));
while (!s.empty()) {
auto node = s.top().first;
auto depth = s.top().second;
s.pop();
if (node->left == nullptr && node->right == nullptr)
result = min(result, depth);
if (node->left && result > depth)
s.push(make_pair(node->left, depth + 1));
if (node->right && result > depth)
s.push(make_pair(node->right, depth + 1));
}
return result;
}
};
相关文章推荐
- leetcode 179 Largest Number
- leetcode 24 Swap Nodes in Pairs
- leetcode 2 Add Two Numbers 方法1
- leetcode 2 Add Two Numbers 方法2
- leetcode----Longest Substring Without Repeating Characters
- [LeetCode]47 Permutations II
- [LeetCode]65 Valid Number
- [LeetCode]123 Best Time to Buy and Sell Stock III
- [LeetCode] String Reorder Distance Apart
- [LeetCode] Sliding Window Maximum
- [LeetCode] Find the k-th Smallest Element in the Union of Two Sorted Arrays
- [LeetCode] Determine If Two Rectangles Overlap
- [LeetCode] A Distance Maximizing Problem
- leetcode_linearList
- leetcode_linearList02
- 021-Merge Two Sorted Lists(合并两个排好序的单链表);leetcode
- LeetCode[Day 1] Two Sum 题解
- LeetCode[Day 2] Median of Two Sorted Arrays 题解
- LeetCode[Day 3] Longest Substring Without... 题解
- LeetCode [Day 4] Add Two Numbers 题解