您的位置:首页 > Web前端 > Node.js

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)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  leetcode python java