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

新余教育网站建设建设部官网网站

新余教育网站建设,建设部官网网站,微信电商怎样开店,县级林业网站建设管理1 题目描述 题目链接:左叶子之和 2 解答思路 递归分为三步,接下来就按照这三步来思考问题 第一步:挖掘出相同的子问题 (关系到具体函数头的设计) 第二步:只关心具体子问题做了什么 (关系…

1 题目描述

题目链接:左叶子之和
在这里插入图片描述

2 解答思路

递归分为三步,接下来就按照这三步来思考问题

第一步:挖掘出相同的子问题  (关系到具体函数头的设计)
第二步:只关心具体子问题做了什么  (关系到具体函数体怎么写,是一个宏观的过程)
第三步:找到递归的出口,防止死递归  (关系到如何跳出递归)

2.1 相同的子问题(函数头设计)

相同的子问题:寻找二叉树的左叶子,就是寻找二叉树的左子树的左叶子和右子树的左叶子。

根据相同的子问题,思考具体的方法:将所有的左叶子放入到一个vector中,最后使用循环将值相加到一起。

下面是leetcode给的接口:

    int sumOfLeftLeaves(TreeNode* root) {}

传入一个TreeNode* 类型的参数,返回是左叶子的和,int类型。

根据之前的分析,我们的参数是一个TreeNode*类型,还有一个vector< int>类型。因为值存储在vector中,最终计算,所以返回值类型为void。最终函数头的设计如下:

    void sum(TreeNode* root, vector<int>& res){}

2.2 具体的子问题做了什么(函数体的实现)

具体子问题做了什么:

1.首先判断该节点的左孩子是不是叶子节点,如果是,则加入到vector中。
2.在当前节点的左子树中寻找
3.在当前节点的右子树中寻找

递归的出口:当前节点为空。

最终函数体的书写:

    void sum(TreeNode* root, vector<int>& res){if (root == nullptr)return;//如果当前节点有左孩子 并且 左孩子为叶子节点if ((root->left) && ((root->left->left == nullptr) && (root->left->right == nullptr)))res.push_back(root->left->val);  //将左孩子的值加入到vector中//递归左子树sum(root->left, res);//递归右子树sum(root->right, res);}

3 总结

class Solution {
public:int sumOfLeftLeaves(TreeNode* root) {vector<int> res;sum(root, res);int s = 0;for (int i = 0; i < res.size(); ++ i){s += res[i];}return s;}//只要叶子节点void sum(TreeNode* root, vector<int>& res){if (root == nullptr)return;//如果当前节点有左孩子 并且 左孩子为叶子节点if ((root->left) && ((root->left->left == nullptr) && (root->left->right == nullptr)))res.push_back(root->left->val);  //将左孩子的值加入到vector中//递归左子树sum(root->left, res);//递归右子树sum(root->right, res);}
};
1. 相同的子问题:寻找二叉树的左叶子,就是寻找二叉树的左子树的左叶子和右子树的左叶子。
2. 具体子问题做了什么:首先判断该节点的左孩子是不是叶子节点,如果是,则加入到vector中。在当前节点的左子树中寻找。在当前节点的右子树中寻找。
3. 递归的出口:当前节点为空。

在这里插入图片描述

http://www.yayakq.cn/news/805963/

相关文章:

  • 旅游网站开发设计如何创建自媒体手机网站
  • 建设网站用什么好烟台seo快速排名
  • 宁波搭建网站公模仿淘宝详情页做网站
  • 网站维护怎么学学院二级网站建设方案模板
  • 做网站傻瓜做网站电话号码
  • 网站开发小组分工不需要备案如何做网站
  • 北京网站排名方案九江县建设规划局网站
  • 如何免费做网站并发布网站建设论团
  • 如何做融资网站网站制作熊猫建站
  • 哪里有网站开发公司被老板抓到用公司产品做自己的网站
  • 绘画做动作的网站黄冈网站官方登录平台
  • 商务网站建设策划书范文火车头采集wordpress发布
  • 农村网站建设的意义淮南网站开发
  • 佛山网站营销网站开发 书
  • 南宁网站排名优化电话办网
  • 个人网站可以做健康付费知识检测网站的seo效果
  • 企业品牌网站建设方案免费网页下载
  • 网站推广全过程做营销型网站 推广的好处
  • 广州网站开发多少钱网站备案在哪个部门
  • 做电商网站需要注册什么公司名称WordPress预览出错
  • 网站建设外包公司怎么样爱网卡
  • ar做网站做网站域名公司
  • 网站宣传流程网页制作源代码模板
  • 网站中加入地图英文网站推广公司
  • 网站建设账务处理属于什么费用wordpress 白色
  • 商城网站建设 上海湖北营销型网站建设公司
  • 重庆网站建设帝维科技德国室内设计网app
  • 平面设计资料网站中国十大培训机构影视后期
  • 哪个网站做调查赚钱多网站建设方案打包
  • 个人网站尺寸北京快速建站制作公司