当前位置: 首页 > 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.15wanjia.com/news/158419.html

相关文章:

  • 海口小学网站建设西安建网站价格
  • 网站防火墙怎么做做网站时如何确定网站主题
  • 开通网站费可以做待摊费用吗建网站什么赚钱
  • 淘宝联盟交钱建设网站个人中心页面模板
  • 株洲网站建设优化企业英文网站怎么推广
  • 个人网站备案可以做公司网站用个人网站免费注册
  • 网站ip域名查询wordpress标签墙
  • 建设银行网站转账建站程序免费下载
  • 哪个网站卖自己做的手工艺品建设境外网站
  • 做碳循环的网站网站建设如何制作教程
  • 新闻录入网站模板wordpress 管理员密码忘记
  • wordpress添加登录注册按钮桂林网站优化价格
  • 网站使用教程app软件开发需要多少钱
  • wordpress点击阅读全文龙华优化公司
  • 网站推广的作用是什么网站开发 保密期限
  • 一般做网站的宽度怎么处理的seo排名是啥
  • 多站点cms济南专业网站优化
  • 郑州网站推广汉狮网络静安区网站开发
  • 厦门市建设局网站规划标准网站建设服务合同 律师
  • 江苏做网站怎么收费多少萝岗微网站建设
  • 潜江公司做网站高校思政课网站建设
  • 云主机建多个网站wordpress首页flash
  • 上海平台网站开发装修平台哪个好
  • 游戏网站开发公司网站建设课设心得体会
  • 服装印花图案网站辽宁省建设工程造价管理协会网站
  • 枣庄住房和城市建设局网站北京网站优化 卓立海创
  • 做网站建设公司crm在线网站 系统 的开发技术
  • 网站域名自己做北京快三是官方的吗
  • 网站建设中 模版wordpress加密视频播放器
  • 小米wifi设置网址入口网站wordpress侧栏显示指定分类