【LeetCode热题100】--199.二叉树的右视图

199.二叉树的右视图

思路:

使用根->右->左方法进行遍历节点,同时记录层数,将当前层数与记录的层数进行比较,如果当前层数大于记录的层数,添加该元素,若当前层数小于记录的层数,说明该层已经有元素被记录,就跳过,这样保证每层第一个被记录的一定是最右边的元素

java 复制代码
/**
 * Definition for a binary tree node.
 * 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;
 *     }
 * }
 */
class Solution {
    int maxHigh = 0;
    List<Integer> res = new ArrayList<Integer>();
    public List<Integer> rightSideView(TreeNode root) {
        dfs(root,1);
        return res;
    }

    public void dfs(TreeNode root,int high){
        if(root == null){
            return ;
        }
        if(maxHigh < high){
            res.add(root.val);
            maxHigh = high;
        }
        dfs(root.right,high + 1);
        dfs(root.left,high + 1);
    }
    
}
相关推荐
wen__xvn6 小时前
基础算法集训第17天:二分查找
算法·leetcode·职场和发展
myloveasuka6 小时前
MREQ̅ 信号
笔记·算法·计算机组成原理
亲爱的非洲野猪7 小时前
动态规划进阶:区间DP深度解析
算法·动态规划
QiZhang | UESTC7 小时前
【算法题学习方法调整】回溯核心逻辑调整:从记代码到套逻辑调整
算法·学习方法
救救孩子把7 小时前
59-机器学习与大模型开发数学教程-5-6 Adam、RMSProp、AdaGrad 等自适应优化算法
人工智能·算法·机器学习
Σίσυφος19007 小时前
PCL 中常用的滤波对比
算法
进击的小头7 小时前
连续系统离散化方法(嵌入式信号处理实战指南)
c语言·算法·信号处理
永远都不秃头的程序员(互关)7 小时前
【决策树深度探索(五)】智慧之眼:信息增益,如何找到最佳决策问题?
算法·决策树·机器学习
智者知已应修善业7 小时前
【输出方形点阵】2024-11-1
c语言·c++·经验分享·笔记·算法
近津薪荼7 小时前
优选算法——双指针专题2(模拟)
c++·学习·算法