您的位置:首页 > 其它

LintCode-二叉树的最大节点

2017-04-08 23:47 155 查看
题目描述:在二叉树中寻找值最大的节点并返回。

样例:

给出如下一棵二叉树:
1
/   \
-5     2
/ \   /  \
0   3 -4  -5


返回值为 
3
 的节点。
做题思路:创建两个树结点,先赋初值,把根结点赋给它们,在考虑左子树和右子树不为空的情况下,用递归函数遍历左子树和右子树,赋给创建的left和right,再比较left和root的大小以找到最大的结点,赋值给root。比较right和root的大小以找到最大的结点,赋值给root,最后返回最大的结点。

关键代码:

class Solution {
public:
/**
* @param root the root of binary tree
* @return the max node
*/
TreeNode* maxNode(TreeNode* root) {
// Write your code here
if(root==NULL) return NULL;
TreeNode *left=root;
TreeNode *right=root;
if (root->left!=NULL)
left=maxNode(root->left);
if (root->right!=NULL)
right=maxNode(root->right);
if (left->val>root->val)
root->val=left->val;
if (right->val>root->val)
root->val=right->val;
return root;
}
};

做题感想:编程错误的时候,出现了两个问题,第一个问题是在创建新的树结点时,赋什么值的时候换了好几种方式,刚开始是root的值,后来又变成了int_min,后来又换回了root,后面最后判断大小返回值的时候,不是谁大就把大的值赋给小的,而是谁大就返回谁,但就是测试数据的时候不对,后来改成这种方式就对了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: