数据结构07
文章目录
- 二叉树的坡度
- 二叉树的右视图
二叉树的坡度
/**
* 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);
}
};
二叉树的右视图
递归:
层次遍历的变体。其中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;
}
};