数据结构07

文章目录

  • 二叉树的坡度
  • 二叉树的右视图

二叉树的坡度

数据结构07_第1张图片

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    int findTilt(TreeNode* root) {
        if(root==NULL)return 0;

        return abs(treesum(root->left)-treesum(root->right))+findTilt(root->left)+findTilt(root->right);       
    }
    int treesum(TreeNode* node){
        if(node==NULL)return 0;
        else return node->val+treesum(node->left)+treesum(node->right);
    }
};

二叉树的右视图

数据结构07_第2张图片
递归:
层次遍历的变体。其中C++和java语言中都有一个重要的if筛选条件,
也就是
条件1.vector或者List的长度小于当前的lever值的时候才将结点的值入vector或者List,
还有一个条件是2.先遍历右孩子再遍历左孩子;
这就保证了始终保留的是最右结点。不妨对照题干上的例子对照进行单步脑海运行一下

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:

void recursion(TreeNode* root,int level,vector<int>& res){

    if(root==NULL)return;
    if(res.size()<level)res.push_back(root->val);
    recursion(root->right,level+1,res);
    recursion(root->left,level+1,res);

}
    vector<int> rightSideView(TreeNode* root) {
        vector<int> res;
        recursion(root,1,res);
        return res;
    }
};

你可能感兴趣的:(数据结构)