代码随想录训练营第17天|110.平衡二叉树,257. 二叉树的所有路径,404.左叶子之和


)

110.平衡二叉树

文章

代码随想录|0110.平衡二叉树

思路

递归,如果左右子树都是平衡二叉树则本节点高度为左右子树深度较大者+1
如果左右子树中有一棵不是平衡二叉树,则本节点为根的树不是平衡二叉树。
难点在如何同时传递两个子树的深度和是不是平衡二叉树的信息。

代码

class Solution {
    public boolean isBalanced(TreeNode root) {
        return getHeight(root) != -1;
    }

    public int getHeight(TreeNode root) {
        if (root == null) {
            return 0;
        }
        int lh = getHeight(root.left);
        int rh = getHeight(root.right);
        if (Math.abs(lh - rh) > 1) {
            return -1;
        }
        if (lh == -1 || rh == -1) {
            return -1;
        }
        return (lh > rh ? lh : rh) + 1; 
    }
}

257. 二叉树的所有路径

文章

代码随想录|0257.二叉树的所有路径

思路

dfs,动态记录路径

代码

class Solution {

    private ArrayList<Integer> order = new ArrayList<>();
    private List<String> res = new ArrayList<>();

    public List<String> binaryTreePaths(TreeNode root) {
        dfs(root);
        return res;
    }

    public void dfs(TreeNode root) {
        
        order.add(root.val);
        if (root.left == null && root.right == null) {
            res.add(convert(order));
            
        }
        if (root.left != null)
            dfs(root.left);
        if (root.right != null)
            dfs(root.right);
        order.remove(order.size() - 1);
    }

    public String convert(ArrayList<Integer> list) {
        StringBuilder sb = new StringBuilder();
        int i, n;
        n = list.size();
        sb.append(list.get(0).toString());
        for (i = 1; i < n; ++i) {
            sb.append("->" + list.get(i));
        }
        return sb.toString();
    }
}

404. 左叶子之和

文章

代码随想录|0404.左叶子之和

思路

遍历所有非空的非叶子节点,如果其左孩子节点为叶子节点则求和

代码

class Solution {
    public int sumOfLeftLeaves(TreeNode root) {
        int res = 0;
        Stack<TreeNode> st = new Stack<>();
        if (root != null && !checkLeaf(root)) {
            st.push(root);
        }
        TreeNode node;
        while (!st.isEmpty()) {
            node = st.pop();
            if (node.left != null && !checkLeaf(node.left)) {
                st.push(node.left);
            } else if (node.left != null) {
                res += node.left.val;
            }
            if (node.right != null && !checkLeaf(node.right)) {
                st.push(node.right);
            }
        }
        return res;
    }

    public boolean checkLeaf(TreeNode node) {
        return node.left == null && node.right == null;
    }
}

总结

递归方法不太好想了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值