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

网站建设合同纠纷管辖百度信息流广告平台

网站建设合同纠纷管辖,百度信息流广告平台,北京外贸网站开发,城阳做网站的题目 给定一棵二叉树和一个值sum,求二叉树中节点值之和等于sum的路径的数目。路径的定义为二叉树中顺着指向子节点的指针向下移动所经过的节点,但不一定从根节点开始,也不一定到叶节点结束。例如,在如图8.5所示中的二叉树中有两条…

题目

给定一棵二叉树和一个值sum,求二叉树中节点值之和等于sum的路径的数目。路径的定义为二叉树中顺着指向子节点的指针向下移动所经过的节点,但不一定从根节点开始,也不一定到叶节点结束。例如,在如图8.5所示中的二叉树中有两条路径的节点值之和等于8,其中,第1条路径从节点5开始经过节点2到达节点1,第2条路径从节点2开始到节点6。
在这里插入图片描述

分析

虽然路径不一定从根节点开始,但仍然可以求得从根节点开始到达当前遍历节点的路径所经过的节点值之和。

如果在路径上移动时把所有累加的节点值之和都保存下来,然后移动的过程中求差值,就容易知道是否存在从任意节点出发的值为给定sum的路径。

有了前面的经验,就可以采用二叉树深度优先搜索来解决与路径相关的问题。当遍历到一个节点时,先累加从根节点开始的路径上的节点值之和,再计算到它的左右子节点的路径的节点值之和。这就是典型的前序遍历的顺序。

public class Test {public static void main(String[] args) {TreeNode node5 = new TreeNode(5);TreeNode node2 = new TreeNode(2);TreeNode node4 = new TreeNode(4);TreeNode node1 = new TreeNode(1);TreeNode node6 = new TreeNode(6);TreeNode node3 = new TreeNode(3);TreeNode node7 = new TreeNode(7);node5.left = node2;node5.right = node4;node2.left = node1;node2.right = node6;node4.left = node3;node4.right = node7;int result = pathSum(node5, 8);System.out.println(result);}public static int pathSum(TreeNode root, int sum) {Map<Integer, Integer> map = new HashMap<>();map.put(0, 1);// 节点和为0的路径有一个(空路径)// path: 遍历节点的路径和return dfs(root, sum, map, 0);}private static int dfs(TreeNode root, int sum, Map<Integer, Integer> map, int path) {if (root == null) {return 0;}// 前序遍历path += root.val;int count = map.getOrDefault(path - sum, 0);// 深度优先遍历,如果以前存在这个差值,那么和当前路径一定是以前路径的延伸map.put(path, map.getOrDefault(path, 0) + 1);count += dfs(root.left, sum, map, path);count += dfs(root.right, sum, map, path);// 当前这个节点遍历完成,重回当前节点的父节点继续遍历。map.put(path, map.get(path) - 1);return count;}
}
http://www.15wanjia.com/news/16249.html

相关文章:

  • 企业网站建设常见问题资源网站排名优化seo
  • 北京app制作seo二级目录
  • 做网站免费搭建搭建一个网站需要多少钱?
  • 专业vi设计哪家好河北seo基础
  • 天王手表官方网站项目营销策划方案
  • 深圳建设局网站打不开seo外包顾问
  • 公司的网站开发部门叫什么百度seo权重
  • html5手机网站制作教程百度网址大全手机版
  • 北京企业官网网站建设报价项目推广
  • 怎么介绍自己的网页设计关键词智能优化排名
  • 如何做网站的登录注册嘉兴seo排名外包
  • wordpress短代码怎么用网站网页的优化方法
  • 做外贸网站能用虚拟主机吗灰色行业关键词推广
  • 网站建设流程及细节私域流量和裂变营销
  • 淘宝优惠卷网站怎么做微信营销怎么做
  • 腾讯云做网站怎么样iis搭建网站
  • 学做网站需要多久t和p在一起怎么做网站
  • 电商运营网站设计seo快速排名软件案例
  • 营销网站模板htlm石家庄seo培训
  • js网站下拉置顶代码营销型网站外包
  • 手机pc网站模板搜索引擎营销的特点包括
  • 旅游网站开发与设计论文品牌全网推广
  • 政府网站群集约化建设优速网站建设优化seo
  • 建设网站需要多少时间google浏览器下载
  • 网站建设运营公司排行班级优化大师使用指南
  • 宁波网站改版企业网站优化关键词
  • 在那些网站做宣传更好新泰网站设计
  • 做网站功能模块竞价推广开户电话
  • 手机网站 布局佛山做网站建设
  • 湖北网站定制开发价格表软文网站模板