当前位置:   article > 正文

二叉树的左、右叶子节点之和_求二叉树左子树之和右子树之和

求二叉树左子树之和右子树之和

一 基础

从百科摘个定义:

在计算机科学中,二叉树是每个结点最多有两个子树的树结构。通常子树被称作“左子树”(left subtree)和“右子树”(right subtree)。二叉树常被用于实现二叉查找树和二叉堆。

一棵深度为k,且有2^k-1个结点的二叉树,称为满二叉树。这种树的特点是每一层上的结点数都是最大结点数。而在一棵二叉树中,除最后一层外,若其余层都是满的,并且或者最后一层是满的,或者是在右边缺少连续若干结点,则此二叉树为完全二叉树。具有n个结点的完全二叉树的深度为floor(log2n)+1。深度为k的完全二叉树,至少有2k-1个叶子结点,至多有2k-1个结点。

二 节点 

  1. public class TreeNode{
  2. int data; //节点内的元素
  3. TreeNode leftNode; //左子树
  4. TreeNode rightNode; //右子树
  5. public TreeNode(int data,TreeNode leftNode,TreeNode rightNode){
  6. this.data =data;
  7. this.leftNode = leftNode;
  8. this.rightNode = rightNode;
  9. }
  10. public String toString() {
  11. return "TreeNode [data=" + data + ", leftNode=" + leftNode + ", rightNode=" + rightNode + "]";
  12. }
  13. }

三 初始化及求分别求左叶子节点和、右叶子节点和

图片来自:https://blog.csdn.net/qq_36186690/article/details/80699770

主要实现依赖了递归。初始化跟求叶子节点和都是。

  1. /**
  2. *
  3. * @author bohu83
  4. *
  5. */
  6. public class LeftsubTreeSum {
  7. public static void main(String[] args) {
  8. // TODO Auto-generated method stub
  9. int num[] = {4,2,1,3,5,7,6,8};
  10. //init
  11. TreeNode node = new TreeNode(num[0],null,null);
  12. for(int i=1;i< num.length;i++){
  13. add(node,new TreeNode(num[i],null,null) );
  14. }
  15. System.out.println(node);
  16. //leftleaf求和
  17. int lsum =leftLeafSum(node);
  18. System.out.println(lsum);
  19. //rightleaf求和
  20. int rsum =rightLeafSum(node);
  21. System.out.println(rsum);
  22. }
  23. public static int rightLeafSum( TreeNode root ){
  24. int rres =0;
  25. if(root == null){
  26. return 0;
  27. }
  28. if(root.rightNode!=null && root.rightNode.leftNode== null && root.rightNode.rightNode== null ){
  29. rres += root.rightNode.data;
  30. }
  31. return rres+ rightLeafSum(root.leftNode )+ rightLeafSum( root.rightNode);
  32. }
  33. public static int leftLeafSum(TreeNode root ){
  34. int res = 0;
  35. if(root == null) {
  36. return res;
  37. }
  38. //判断叶子节点
  39. if(root.leftNode != null && root.leftNode.leftNode== null && root.leftNode.rightNode== null){
  40. res += root.leftNode.data;
  41. }
  42. return res+ leftLeafSum(root.leftNode )+leftLeafSum(root.rightNode );
  43. }
  44. public static void add(TreeNode node,TreeNode next){
  45. //插右侧
  46. if(next.data >= node.data){
  47. if(node.rightNode== null){
  48. node.rightNode = next;
  49. }else{//递归
  50. add(node.rightNode,next);
  51. }
  52. }else{
  53. //插左侧
  54. if(node.leftNode == null){
  55. node.leftNode = next;
  56. }else{
  57. add(node.leftNode,next);
  58. }
  59. }
  60. }
  61. static class TreeNode{
  62. int data; //节点内的元素
  63. TreeNode leftNode; //左子树
  64. TreeNode rightNode; //右子树
  65. public TreeNode(int data,TreeNode leftNode,TreeNode rightNode){
  66. this.data =data;
  67. this.leftNode = leftNode;
  68. this.rightNode = rightNode;
  69. }
  70. public String toString() {
  71. return "TreeNode [data=" + data + ", leftNode=" + leftNode + ", rightNode=" + rightNode + "]";
  72. }
  73. }
  74. }

输出:

TreeNode [data=4, leftNode=TreeNode [data=2, leftNode=TreeNode [data=1, leftNode=null, rightNode=null], rightNode=TreeNode [data=3, leftNode=null, rightNode=null]], rightNode=TreeNode [data=5, leftNode=null, rightNode=TreeNode [data=7, leftNode=TreeNode [data=6, leftNode=null, rightNode=null], rightNode=TreeNode [data=8, leftNode=null, rightNode=null]]]]
7
11
 

参考:

https://blog.csdn.net/qq_36186690/article/details/80699770

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/551329
推荐阅读
相关标签
  

闽ICP备14008679号