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

网站建设 公司关键词免费网站

网站建设 公司,关键词免费网站,济南建站详情,花生棒 做网站题目描述 给出一个二叉树,请由该二叉树生成一个新的二叉树,它满足其树中的每个节点将包含原始树中的左子树和右子树的和。左子树表示该节点左侧叶子节点为根节点的一颗新树;右子树表示该节点右侧叶子节点为根节点的一颗新树。 输入描述 2行整数&#…

题目描述

给出一个二叉树,请由该二叉树生成一个新的二叉树,它满足其树中的每个节点将包含原始树中的左子树和右子树的和。左子树表示该节点左侧叶子节点为根节点的一颗新树;右子树表示该节点右侧叶子节点为根节点的一颗新树。

输入描述

2行整数,第1行表示二叉树的中序遍历,第2行表示二叉树的前序遍历,以空格分割。

输出描述

1行整数,表示求和树的中序遍历,以空格分割。

例1:

输入:
-3 12 6 8 9 -10 -7
8 12 -3 6 -10 9 -7
输出:
0 3 0 7 0 2 0
/*
-3 12 6 8 9 -10 -7
8 12 -3 6 -10 9 -7
0 3 0 7 0 2 0*/
public class 二叉树计算 {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int[] mid = Arrays.stream(sc.nextLine().trim().split(" ")).mapToInt(Integer::parseInt).toArray();int[] pre = Arrays.stream(sc.nextLine().trim().split(" ")).mapToInt(Integer::parseInt).toArray();// 构建树Node root = buildTree(mid, pre);// 计算每个节点的值sumTree(root);// 中序遍历输出结果printRes(root);}private static void printRes(Node root) {if (root == null){return;}printRes(root.left);System.out.print(root.val + " ");printRes(root.right);}private static Integer sumTree(Node node) {if (node == null){return 0;}int nodeLeftSum = sumTree(node.left);int nodeRightSum = sumTree(node.right);int valOld = node.val;node.val = nodeLeftSum + nodeRightSum;return node.val + valOld;}private static Node buildTree(int[] mid, int[] pre) {HashMap<Integer, Integer> midMap = new HashMap<>();for (int i = 0; i < mid.length; i++) {midMap.put(mid[i], i);}return getTree(pre, 0, pre.length-1, mid, 0, mid.length-1, midMap);}private static Node getTree(int[] pre, int preIndexStart, int preIndexEnd, int[] mid,int midIndexStart, int midIndexend, HashMap<Integer, Integer> midMap) {if (preIndexStart > preIndexEnd || midIndexStart > midIndexend){return null;}int rootVal = pre[preIndexStart];Node root = new Node(rootVal);// 根据root节点在中序遍历中的下标,可以获取root节点的左右节点的长度Integer midRootIndex = midMap.get(rootVal);int leftSize = midRootIndex - midIndexStart;root.left = getTree(pre,preIndexStart+1,preIndexStart + leftSize,mid, midIndexStart, midRootIndex - 1, midMap);root.right = getTree(pre,preIndexStart + leftSize + 1,preIndexEnd,mid, midRootIndex + 1, midIndexend, midMap);return root;}static class Node{int val;Node left;Node right;public Node(int val) {this.val = val;}}
}

http://www.khdw.cn/news/659.html

相关文章:

  • 重庆城乡建设信息网官网想找搜索引擎优化
  • 知名企业网站搭建网址大全网站
  • 网站备案 网站重庆seo论
  • 企业管理培训课程有哪些内容seo是怎么优化上去
  • 电气工程及其自动化seo助力网站转化率提升
  • python 做网站模块上海外贸seo公司
  • 互联网营销方法有哪些seo需要懂代码吗
  • 租一个服务器建网站多少钱做百度推广代运营有用吗
  • 深圳b2c网站构建百度小说官网
  • 网站制作好在百度里可以搜到吗百度推广入口
  • 腾讯网站开发语言郑州seo全网营销
  • app和微网站的区别线上销售水果营销方案
  • 做程序网站需要什么代码百度账号官网
  • 深圳网站公司经典的软文广告
  • php网站换服务器新出的app推广在哪找
  • 企业模板建站公司口碑营销的概念
  • 杭州做网站的科技公司百度 竞价排名
  • 网站备案规则百度商店应用市场
  • 做微视频的网站seo快速排名网站优化
  • 旗袍网站架构手机上制作网页
  • 代人做网站如何做谷歌优化
  • 沧州网站建设优化seo百度网站排名软件
  • 如何快速做单页面网站汽车网站建设
  • 盘锦网站建设兼职知了seo
  • 专业的网页设计和网站制作公司安徽360优化
  • dw做网站怎么替换字体网络推广代理平台
  • 百度客服中心人工在线南宁百度推广seo
  • 品牌网站建设专业定制婚恋网站排名前10
  • 全国做网站的大公司营销策划咨询
  • 济南食品行业网站开发竞价外包代运营公司