9.9算法练习

完全二叉树的节点个数

java 复制代码
public class countNodes {
    public class TreeNode {
     int val;
      TreeNode left;
      TreeNode right;
      TreeNode() {}
      TreeNode(int val) { this.val = val; }
      TreeNode(int val, TreeNode left, TreeNode right) {
          this.val = val;
          this.left = left;
          this.right = right;
      }
  }
  private int getHeight(TreeNode root){
        if (root==null){
            return 0;
        }
//树的总高度是由根节点和它的最高子树决定的
        return 1+getHeight(root.left);
  }
    public int countNodes(TreeNode root) {
if (root==null){
    return 0;
}
int leftHeight=getHeight(root.left);
int rightHeight=getHeight(root.right);
//如果左子树是二叉树
if (leftHeight==rightHeight){
    //左子树节点个数:2^h-1
    int leftNodes=(int)Math.pow(2,leftHeight)-1;
    //总节点个数:左子树节点个数+根节点+右子树节点个数(递归计算)
    return leftNodes+1+countNodes(root.right);
}else{
    //否则右子树是满二叉树(或者少一个节点),但我们可以认为他是完全二叉树的一部分
    //右子树节点个数
    int rightNodes=(int)Math.pow(2,rightHeight)-1;
    return rightNodes+1+countNodes(root.left);
}
    }
}

1、如果树为空(即root为null),则节点的个数为0。

2、否则,我们递归的计算左子树和右子树的节点个数。

3、在递归过程中,我们需要知道子数的高度,因为完全二叉树的节点个数和高度密切相关。

4、如果左子树的高度等于右子树的高度,那么左子树是一个满二叉树,节点个数可以直接通过公式2^h-1计算(其中h是左子树的高度)。

5、如果左子树的高度大于右子树的高度,那么右子树是一个满二叉树,并且左子树是一个不完全的完全二叉树,节点个数需要分别计算左子树和右子树后相加

  1. 使用递归计算左子树的高度 leftHeight 和右子树的高度 rightHeight。
  2. 如果 leftHeight==rightHeight,那么左子树是满二叉树,节点个数为 2leftHeight−1。
  3. 如果 leftHeight>rightHeight,那么右子树是满二叉树,节点个数为 2rightHeight−1,再加上左子树的节点个数(递归计算)。
  4. 最后,加上根节点 1

二分查找

复制代码
class Solution {
    public int search(int[] nums, int target) {
        int left=0;
        int right=nums.length-1;
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]>target){
                right=mid-1;
            }else if(nums[mid]<target){
                left=mid+1;
            }else{
                return mid;
        }
    }
    return -1;
    }
    }

寻找比目标字母大的最小字母

复制代码
class Solution {
     public char nextGreatestLetter(char[] letters, char target) {
        char result = letters[0];
        boolean found=false;
        for (char letter : letters) {
            if (letter>target){
                result =letter;
                found=true;
                break;
            }
        }
return result;
    }
}
相关推荐
小O的算法实验室20 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
郭涤生21 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿21 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz21 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能21 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****21 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能21 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能21 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo1 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
Proxy_ZZ01 天前
从零实现LDPC比特翻转译码器:C语言实战与底层逻辑解析
c语言·算法