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

做装修网站卖钱工具

做装修网站卖钱,工具,网站设计指南,智慧团建网页给你一棵二叉树,请你返回满足以下条件的所有节点的值之和: 该节点的祖父节点的值为偶数。(一个节点的祖父节点是指该节点的父节点的父节点。) 如果不存在祖父节点值为偶数的节点,那么返回 0 。 示例: 输入…

给你一棵二叉树,请你返回满足以下条件的所有节点的值之和:

该节点的祖父节点的值为偶数。(一个节点的祖父节点是指该节点的父节点的父节点。)
如果不存在祖父节点值为偶数的节点,那么返回 0 。

示例:

在这里插入图片描述

输入:root = [6,7,8,2,7,1,3,9,null,1,4,null,null,null,5]
输出:18
解释:图中红色节点的祖父节点的值为偶数,蓝色节点为这些红色节点的祖父节点。

提示:

树中节点的数目在 1 到 10^4 之间。
每个节点的值在 1 到 100 之间。

法一:直接递归模拟即可:

/*** 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 sumEvenGrandparent(TreeNode* root) {int ans = 0;findAns(root, false, false, ans);return ans;}private:void findAns(TreeNode *node, bool isEvenFather, bool isEvenGrandFather, int &ans){if (node == nullptr){return;}if (isEvenGrandFather){ans += node->val;}findAns(node->left, !(node->val & 1), isEvenFather, ans);findAns(node->right, !(node->val & 1), isEvenFather, ans);}
};

如果树中有n个节点,此算法时间复杂度为O(n),空间复杂度为O(logn)。

法二:广度优先搜索,每遍历到一个偶数节点,将其孙子节点的值加上:

/*** 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 sumEvenGrandparent(TreeNode* root) {queue<TreeNode *> q;q.push(root);int ans = 0;while (!q.empty()){TreeNode *node = q.front();q.pop();if (!(node->val & 1)){if (node->left){if (node->left->left){ans += node->left->left->val;}if (node->left->right){ans += node->left->right->val;}}if (node->right){if (node->right->left){ans += node->right->left->val;}if (node->right->right){ans += node->right->right->val;}}}if (node->left){q.push(node->left);}if (node->right){q.push(node->right);}}return ans;}
};

如果树中有n个节点,此算法时间复杂度为O(n),空间复杂度为O(logn)。

http://www.tj-hxxt.cn/news/107663.html

相关文章:

  • 常德微网站开发就业seo好还是sem
  • 网站排名要怎么做台州seo公司
  • 兼职做国外网站钻前品牌推广外包公司
  • 网站主体负责人国际站seo优化是什么意思
  • 苏州手机网站建设服务安卓优化大师app下载
  • 专业建设网站哪个好自己建网站详细流程
  • 怎样保证网站的安全性it培训四个月骗局
  • 网络营销推广的目的是优化分析
  • 网站可信认证在哪里做一键生成个人网站
  • 中国风配色网站搜索引擎优化方法有哪些
  • 长沙市做网站公司泰州seo推广公司
  • 妹子ui wordpressseo外包公司报价
  • 个人网站制作步骤兰州网站优化
  • 西安网站推广慧创成都网站推广公司
  • 宿迁房价2022最新房价福州seo兼职
  • 做盗版小说网站能赚钱不枸橼酸西地那非片是什么
  • 网站制做公司宁波seo怎么做优化
  • 企业网站php模板下载海南百度推广公司电话
  • 网站标题与关键词怎么制作自己公司网站
  • 织梦摄影网站模板海外黄冈网站推广
  • 贵阳高端网站建设广州网络推广哪家好
  • 同行做的好的网站免费的seo教程
  • 影院网站建设宁波seo快速优化公司
  • 柳州网站优化公司网站推广服务报价表
  • 苏州网站建设凡科常德网站设计
  • 电商网站可以用dw做渠道网官网
  • 丹东电信网站备案域名服务器查询
  • 东营做网站seo推广项目
  • 哈尔滨做网站建设百度账户安全中心
  • 学历提升咨询郑州seo代理商