欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 高考 > 数据结构07

数据结构07

2024/10/25 14:27:56 来源:https://blog.csdn.net/m0_52024881/article/details/141900631  浏览:    关键词:数据结构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;}
};

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com