当前位置: 首页 > news >正文

力扣--树题总结

783. 二叉搜索树节点最小距离

/*** 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 minDiffInBST(TreeNode* root) {int ans = INT_MAX, pre = -1;dfs(root, pre, ans);return ans;}void dfs(TreeNode* root, int& pre, int& ans){//递归返回条件if(root == nullptr){return;}//前-一直递归到左下角dfs(root->left, pre, ans);//中-处理数据,第一次pre保存左下角值if(pre == -1){pre = root->val;}else{//递归退回到左下角父节点,ans取最小ans = min(ans, root->val - pre);//pre更新到当前节点的valpre = root->val;}//后续dfs(root->right, pre, ans);}
};

872. 叶子相似的树

/*** 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:bool leafSimilar(TreeNode* root1, TreeNode* root2) {vector<int> num1;vector<int> num2;inorder(root1, num1);inorder(root2, num2);if(num1.size() != num2.size()) return false;for(int i=0; i< num1.size(); i++){if(num1[i] != num2[i]) return false;}return true;}void inorder(TreeNode* root, vector<int>& num){if(root==nullptr){return;}inorder(root->left, num);if(root->left==nullptr && root->right==nullptr){num.push_back(root->val);}inorder(root->right, num);}
};

 


http://www.mrgr.cn/news/71337.html

相关文章:

  • ES7【2016】、ES8【2017】新增特性(六)
  • 深入Android架构(从线程到AIDL)_22 IPC的Proxy-Stub设计模式04
  • 《Spring Framework实战》6:核心技术 4.1.IoC 容器
  • el-table拖拽表格
  • 信创国产数据库:崛起与创新的力量
  • 怎么把word试题转成excel?
  • JS爬虫实战之TikTok_Shop验证码
  • Linux_1
  • 软件测试基础二十三 (接口测试 集成UnitTest)
  • 【miniMax开放平台-注册安全分析报告】
  • 前端js用canvas合成图片并转file对象
  • 【GPTs】Get Simpsonized:一键变身趣味辛普森角色
  • 2025计算机毕设选题精选推荐【Java方向】
  • PCB过孔分哪些,设计需注意事项
  • VirtualBox和 Vagrant
  • 力扣 LeetCode 977. 有序数组的平方(Day1:数组)
  • docker使用过程中安装wsl的问题wsl update failed错误0x800701bc
  • Python练习19
  • 24/11/12 算法笔记<强化学习> 自注意力机制
  • 【vs主程序 链接 实时生成库的问题】
  • HTTP状态码详解
  • 接口自动化测试实战(全网唯一)
  • integer==与equals()结果不同
  • Node.js笔记
  • 卸载 Python
  • 微澜:用 OceanBase 搭建基于知识图谱的实时资讯流的应用实践