力扣 110.平衡二叉树
题目链接:110. 平衡二叉树 - 力扣(LeetCode)
思路:1.明确递归函数参数和返回值,如果当前传入节点为根节点的二叉树已经不是二叉平衡树了,还返回高度的话就没有意义了。所以如果已经不是二叉平衡树了,可以返回-1 来标记已经不符合平衡树的规则了
2.终止条件仍然是空节点 3.分别求出其左右子树的高度,然后如果差值小于等于1,则返回当前二叉树的高度,否则返回-1,表示已经不是二叉平衡树了。
C++代码:
class Solution {
public:
int getHeight(TreeNode* node){
if(node==nullptr) return 0;
int left=getHeight(node->left);
if(left==-1) return -1;
int right=getHeight(node->right);
if(right==-1) return -1;
return abs(right-left)<=1? 1+max(left,right) : -1;
}
bool isBalanced(TreeNode* root) {
return getHeight(root)==-1 ?false:true;
}
};
力扣 257.二叉树的所有路径
题目链接:257. 二叉树的所有路径 - 力扣(LeetCode)
思路:1.明确递归函数参数和返回值,path存储当前遍历路径,result存储输出结果。2.终止条件是遍历到叶子结点。3.前序遍历,需要先处理中间节点,中间节点就是我们要记录路径上的节点,先放进path中。path 不能一直加入节点,它还要删节点,然后才能加入新的节点。这里引入了回溯过程
C++代码:
class Solution {
void traversal(TreeNode* cur, vector<int>& path, vector<string>& result) {
path.push_back(cur->val); // 中,中为什么写在这里,因为最后一个节点也要加入到path中
// 这才到了叶子节点
if (cur->left == NULL && cur->right == NULL) {
string sPath;
for (int i = 0; i < path.size() - 1; i++) {
sPath += to_string(path[i]);
sPath += "->";
}
sPath += to_string(path[path.size() - 1]);
result.push_back(sPath);
return;
}
if(cur->left){
traversal(cur->left,path,result);
path.pop_back();
}
if(cur->right){
traversal(cur->right,path,result);
path.pop_back();
}
}
public:
vector<string> binaryTreePaths(TreeNode* root) {
vector<string> result;
vector<int> path;
if(root==NULL) return result;
traversal(root,path,result);
return result;
}
};
力扣 404.左叶子之和
题目链接:404. 左叶子之和 - 力扣(LeetCode)
思路:终止条件为空节点和叶子结点,因为叶子节点有左右之分,必须根据父节点发过来判断是否为左叶子节点。递归过程当遇到左叶子节点的时候,记录数值,然后通过递归求取左子树左叶子之和,和 右子树左叶子之和,相加便是整个树的左叶子之和。
C++代码:
class Solution {
public:
int sumOfLeftLeaves(TreeNode* root) {
if(root==nullptr) return 0;
if(root->left==nullptr && root->right==nullptr) return 0;
int left=sumOfLeftLeaves(root->left);
if(root->left!=NULL && root->left->left==nullptr && root->left->right==nullptr)
left=root->left->val;
int right=sumOfLeftLeaves(root->right);
return right+left;
}
};