leetcode的TreeNode工具类

leetcode的TreeNode工具类

场景

刷题的时候,二叉树类型的题目,用里面的示例数据无法快速构建入参进行测试,顾封装了一个工具类。

代码demo

java 复制代码
@Slf4j
@Data
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;
    }

    TreeNode left(int val){
        this.left = new TreeNode(val);
        return this;
    }

    TreeNode right(int val){
        this.right = new TreeNode(val);
        return this;
    }

    private static final String NULL = "null";

    /**
     * 构造树
     * @param nodes
     * @return
     */
    public static TreeNode buildTree(Integer[] nodes){
        if (nodes.length == 0 || (nodes.length == 1 && Objects.isNull(nodes[0]))){
            return null;
        }
        TreeNode root = new TreeNode(nodes[0]);
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        int pos = 1;
        while(!queue.isEmpty() && pos < nodes.length){
            TreeNode node = queue.poll();
            if (Objects.nonNull(nodes[pos])){
                node.left = new TreeNode(nodes[pos]);
                queue.offer(node.left);
            }
            pos++;
            if (pos == nodes.length){
                break;
            }
            if (Objects.nonNull(nodes[pos])){
                node.right = new TreeNode(nodes[pos]);
                queue.offer(node.right);
            }
            pos++;
        }
        return root;
    }


    public static void printTree(TreeNode root){
        if (root == null){
            log.info("[]");
            return;
        }
        StringBuilder builder = new StringBuilder();
        builder.append("[");
        Queue<TreeNode> queue = new LinkedList<>();
        boolean allEmpty = false;
        int size;
        queue.offer(root);
        while (!queue.isEmpty() && !allEmpty){
            allEmpty = true;
            size = queue.size();
            while (size > 0){
                size--;
                TreeNode node = queue.poll();
                if (node == null){
                    builder.append(NULL).append(CommonConstants.COMMA);
                    queue.offer(null);
                    queue.offer(null);
                }
                else {
                    builder.append(node.getVal()).append(CommonConstants.COMMA);
                    queue.offer(node.left);
                    queue.offer(node.right);
                    if (node.left != null || node.right != null){
                        allEmpty = false;
                    }
                }
            }
        }
        builder.replace(builder.length()-1, builder.length(), "]");
        log.info("{}", builder);
    }

    public static void main(String[] args) {
        Integer[] nodes = {4,1,6,0,2,5,7,null,null,null,3,null,null,null,8};
        TreeNode root = buildTree(nodes);



    }


    /**
     * 获得最左元素 如果是二叉搜索树即最小元素
     * @param root
     * @return
     */
    public static TreeNode getLeftest(TreeNode root){
        if (root == null){
            return null;
        }
        TreeNode item = root, result = item;
        while(true){
            if (item.left != null){
                item = item.left;
                result = item;
            }
            else if (item.right != null){
                item = item.right;
            }
            else {
                return result;
            }
        }
    }

    /**
     * 校验两棵树是否一样
     * @param p
     * @param q
     * @return
     */
    public static boolean sameCheck(TreeNode p, TreeNode q){
        if (Objects.isNull(p) && Objects.isNull(q)){
            return true;
        }
        if (Objects.isNull(p) || Objects.isNull(q) || p.getVal() != q.getVal()){
            return false;
        }
        return sameCheck(p.getLeft(), q.getLeft()) && sameCheck(p.getRight(), q.getRight());
    }


    /**
     * 根据字符串值构造数据
     * @param s
     * @return
     */
    public static TreeNode constructNode(String s){
        if (NULL.equals(s)){
            return null;
        }
        return new TreeNode(Integer.parseInt(s));
    }

}

参考地址

github参考demo

相关推荐
2501_908329852 分钟前
实时音频处理C++实现
开发语言·c++·算法
dapeng28702 分钟前
移动语义与完美转发详解
开发语言·c++·算法
bbbb3655 分钟前
算法工程中的可扩展性与分布式实现方案的技术7
算法
Shining05965 分钟前
AI 编译器系列(六)《Stable Diffusion 在 InfiniTensor 推理框架中的适配与工程实践》
人工智能·算法·stable diffusion·大模型·图像生成·ai编译器·infinitensor
佩奇大王6 分钟前
P159 摆动序列
java·开发语言·算法
weixin_537590456 分钟前
《C程序设计语言》练习答案(练习1-7)
linux·c语言·算法
!停10 分钟前
C++基础入门(缺省参数,函数重载,引用)
开发语言·c++·算法
我不是秋秋10 分钟前
软件开发项目各角色关系解析:产品/前后端/测试如何高效协作?
java·算法·面试·职场和发展·哈希算法
Tisfy12 分钟前
LeetCode 1886.判断矩阵经轮转后是否一致:模拟
算法·leetcode·矩阵·题解·模拟
dapeng28702 小时前
分布式系统容错设计
开发语言·c++·算法