leetcode 671 Second Minimum Node In a Binary Tree
2018-01-15 09:52
260 查看
Java
class Solution {
public int findSecondMinimumValue(TreeNode root) {
if(root==null) return -1;
if(root.left==null && root.right==null) return -1;
int left=root.left.val;
int right=root.right.val;
if(root.left.val==root.val){
left = findSecondMinimumValue(root.left);
}
if(root.right.val==root.val){
right = findSecondMinimumValue(root.right);
}
if(left!=-1&&right!=-1) return Math.min(left,right);
else if(left==-1) return right;
else return left;
}
}Python
class Solution:
def findSecondMinimumValue(self, root):
"""
:type root: TreeNode
:rtype: int
"""
if not root:
return -1
if not root.left and not root.right:
return -1
left,right=root.left.val,root.right.val
if root.left.val==root.val:
left=self.findSecondMinimumValue(root.left)
if root.right.val==root.val:
right=self.findSecondMinimumValue(root.right)
if left==-1 or right==-1:
return -left*right
else:
return min(left,right)
class Solution {
public int findSecondMinimumValue(TreeNode root) {
if(root==null) return -1;
if(root.left==null && root.right==null) return -1;
int left=root.left.val;
int right=root.right.val;
if(root.left.val==root.val){
left = findSecondMinimumValue(root.left);
}
if(root.right.val==root.val){
right = findSecondMinimumValue(root.right);
}
if(left!=-1&&right!=-1) return Math.min(left,right);
else if(left==-1) return right;
else return left;
}
}Python
class Solution:
def findSecondMinimumValue(self, root):
"""
:type root: TreeNode
:rtype: int
"""
if not root:
return -1
if not root.left and not root.right:
return -1
left,right=root.left.val,root.right.val
if root.left.val==root.val:
left=self.findSecondMinimumValue(root.left)
if root.right.val==root.val:
right=self.findSecondMinimumValue(root.right)
if left==-1 or right==-1:
return -left*right
else:
return min(left,right)
相关文章推荐
- 【LeetCode】671. Second Minimum Node In a Binary Tree 解题报告
- [LeetCode 671] Second Minimum Node In a Binary Tree
- leetcode 671. Second Minimum Node In a Binary Tree
- LeetCode 671. Second Minimum Node In a Binary Tree
- [Leetcode] 671. Second Minimum Node In a Binary Tree 解题报告
- leetcode 671. Second Minimum Node In a Binary Tree
- leetcode 671. Second Minimum Node In a Binary Tree
- [LeetCode] 671. Second Minimum Node In a Binary Tree
- leetcode(671):Second Minimum Node In a Binary Tree
- leetcode 671. Second Minimum Node In a Binary Tree 第二小数字 + 深度优先遍历DFS
- LeetCode 671. Second Minimum Node In a Binary Tree
- Leetcode671. Second Minimum Node In a Binary Tree
- leetcode 671. Second Minimum Node In a Binary Tree
- LeetCode - 671. Second Minimum Node In a Binary Tree
- 671. Second Minimum Node In a Binary Tree
- 671. Second Minimum Node In a Binary Tree
- 671. Second Minimum Node In a Binary Tree
- 671. Second Minimum Node In a Binary Tree
- [LeetCode] Second Minimum Node In a Binary Tree 二叉树中第二小的结点
- 671. Second Minimum Node In a Binary Tree