我是靠谱客的博主 外向红酒,这篇文章主要介绍leetcode 671 Second Minimum Node In a Binary Tree,现在分享给大家,希望可以做个参考。

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 671 Second Minimum Node In a Binary Tree的全部内容,更多相关leetcode内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部