【二叉树】如何构建一个包含大量随机数节点的二叉树测试用例

news2025/1/9 2:01:57

【二叉树】如何构建一个包含大量随机数节点的二叉树测试用例

  • 前言
  • 一、案例准备
  • 二、自动生成随机二叉树工具类(TreegenerateUtils)
  • 三、如何调用随机二叉树工具类(TreegenerateUtils)?


前言

今天笔者在测试有关二叉树的测试用例时,发现一点一点给节点添加孩子操作十分繁琐,于是写了一个自动生成二叉树测试用例函数,供大家参考。


一、案例准备

准备了一个二叉树节点类Node如下图所示

在这里插入图片描述


二、自动生成随机二叉树工具类(TreegenerateUtils)


  如下面代码所示,定义了一个TreegenerateUtil工具类,其中包含有静态方法generate自动生成随机二叉树,其中该方法有两个重载实现,该方法返回一个随机二叉树实例的根节点,其中两个重载方法都需要四个参数,其中前三个参数相同为currentDepth(树的深度),MaxDepth(树的最大深度),MaxValue(树的每个节点可以达到的最大值),最后一个参数第一个重载方法为Random类实例,目的是使得每次生成的随机树不同,而第二个重载方法的参数为Int数字,跟第一个重载方法也是同样的目的


package net.mooctest;

import java.util.Random;

/**
 * @ClassName TreeUtils
 * @Description
 * @Author chougou
 * @Date 2023年11月10日 21:19
 * @Version 1.0
 */
public class TreegenerateUtils {
    public static Node generate(int currentDepth, int MaxDepth, int MaxValue, Random random1) {       //currentDepth为当前深度,MaxDepth为树的最大深度,MaxValue为节点可以达到的最大数,均可自行调节,random为随机数种子
        //因为每次递归深度不同,因此currentDepth+random可作为随机数种子

        if (currentDepth >= MaxDepth) {                     //当递归树的深度超过MaxDepth时候,递归结束

            return new Node(random1.nextInt(MaxValue));
        } else {

            Node node = new Node(random1.nextInt(MaxValue));
            //随机添加左孩子或者右孩子或者左右孩子或者无孩子
            //1,只添加左孩子
            int temp = random1.nextInt(100);
            if (temp % 3 == 0) {
                Node nodeleft = generate(currentDepth + 1, MaxDepth, MaxValue, random1);
                node.left = nodeleft;
            }
            //2.只添加右孩子
            if (temp % 3 == 1) {
                Node noderight = generate(currentDepth + 1, MaxDepth, MaxValue, random1);
                node.right = noderight;
            }
            //3.左右孩子均添加
            if (temp % 3 == 2) {

                Node noderight = generate(currentDepth + 1, MaxDepth, MaxValue, random1);
                Node nodeleft = generate(currentDepth + 1, MaxDepth, MaxValue, random1);
                node.left = nodeleft;
                node.right = noderight;

            }
            //4.最后一种即什么也不添加
            return node;

        }


    }

    public static Node generate(int currentDepth, int MaxDepth, int MaxValue, int random) {       //currentDepth为当前深度,MaxDepth为树的最大深度,MaxValue为节点可以达到的最大数,均可自行调节,random为随机数种子
        Random random1 = new Random(currentDepth + random);        //因为每次递归深度不同,因此currentDepth+random可作为随机数种子

        if (currentDepth >= MaxDepth) {                     //当递归树的深度超过MaxDepth时候,递归结束

            return new Node(random1.nextInt(MaxValue));
        } else {

            Node node = new Node(random1.nextInt(MaxValue));
            //随机添加左孩子或者右孩子或者左右孩子或者无孩子
            //1,只添加左孩子
            int temp = random1.nextInt(100);
            if (temp % 3 == 0) {
                Node nodeleft = generate(currentDepth + 1, MaxDepth, MaxValue, random);
                node.left = nodeleft;
            }
            //2.只添加右孩子
            if (temp % 3 == 1) {
                Node noderight = generate(currentDepth + 1, MaxDepth, MaxValue, random);
                node.right = noderight;
            }
            //3.左右孩子均添加
            if (temp % 3 == 2) {

                Node noderight = generate(currentDepth + 1, MaxDepth, MaxValue, random);
                Node nodeleft = generate(currentDepth + 1, MaxDepth, MaxValue, random);
                node.left = nodeleft;
                node.right = noderight;

            }
            //4.最后一种即什么也不添加
            return node;

        }


    }
}




三、如何调用随机二叉树工具类(TreegenerateUtils)?


  如下面程序示例,通过调用TreegenerateUtils的静态函数generate生成4个根节点,其中每个根节点均不相同


 @Test
    public void testTreegenerateUtils(){

        //下面生成四个最大深度为10,节点可达到最大值为100的四个随机二叉树实例
        Random random1=new Random();
       Node root1=TreegenerateUtils.generate(1,10,100,random1.nextInt());
       Node root2=TreegenerateUtils.generate(1,10,100,random1.nextInt());
       Node root3=TreegenerateUtils.generate(1,10,100,random1);
       Node root4=TreegenerateUtils.generate(1,10,100,random1);
    }

运行结果展示:(每个根节点均不相同)
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1193750.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

打开ps提示,计算机中丢失d3dcompiler_47.dll怎么解决?

“d3dcompiler_47.dll丢失5个解决办法”。相信很多同事在工作或者娱乐的过程中,都遇到过这个错误提示。那么,究竟什么是d3dcompiler_47.dll文件?为什么会丢失呢?又该如何解决这个问题呢?接下来,我将为大家详…

财税服务展示预约小程序的作用是什么

财税财政往往困扰着很多公司,尤其是公司里没有相应职员或工作压力大的情况下,不少商家就会寻找代理记账、审计服务、会计代理等服务的机构。 对财政服务代理机构(会计公司)来说,市场企业多而广,理论上来说…

yolov5 利用Labelimg对图片进行标注

首先打开yolov5-master,在data文件中新建一个文件夹来存放你需要跑的数据,例如我这次跑的是羽毛球,文件把文件取名为badminton。使用其他文件夹例如images也可以,就是跑多了以后不好整理,然后点击 选中刚刚你存放数据的…

【算法 | 数论 No.1】AcWing1246. 等差数列

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【AcWing算法提高学习专栏】 🍔本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程&a…

c: struct sort descending and ascending in windows and Ubuntu

/*** file StudentStructSort.h* author geovindu,Geovin Du,涂聚文 (geovindu163.com)* ide: vscode c11,c17 Ubuntu 22.4* brief 结构体排序示例* date 2023-11-05* version 0.1* copyright geovindu 站在巨人的肩膀上 Standing on the Shoulders of Giants**/#ifnd…

easyexcel==省市区三级联动

省市区三级联动,不选前面的就没法选后面的 package com.example.demoeasyexcel.jilian2; import com.alibaba.excel.write.metadata.holder.WriteSheetHolder; import com.alibaba.excel.write.metadata.holder.WriteWorkbookHolder; import org.apache.poi.ss.use…

​软考-高级-系统架构设计师教程(清华第2版)【第2章 计算机系统基础知识-思维导图】​

软考-高级-系统架构设计师教程(清华第2版)【第2章 计算机系统基础知识-思维导图】 课本里章节里所有蓝色字体的思维导图

MySQL | 查询接口性能调优、编码方式不一致导致索引失效

背景 最近业务反馈,列表查询速度过慢,需要优化。 到正式环境系统去验证,发现没筛选任何条件的情况下,查询需要三十多秒,而筛选了条件之后需要13秒。急需优化。 先说结论:连表用的字段编码方式不一致导致索…

【异常----finally和自定义异常】

文章目录 finally练习问题 异常的处理流程【异常处理流程总结】自定义异常类 finally 有些特定的代码,不论程序是否发生异常,都需要执行,比如程序中打开的资源:在程序正常或者异常退出时,必须要对资源进进行回收。另外…

Halcon Variable Inspect 安装失败

版本 Visual Studio 2022Halcon 20.11 找到Halcon 扩展文件 输入CMD 经过下面博客所示步骤,修改Visual Studio 对应版本 Halcon Variable Inspect 安装失败 替换成功!

混淆矩阵和相应参数详解

如果一个模型在能够尽量捕获少数类的情况下,还能够尽量对多数类判断正确,则这个模型就非常优秀了。为了评估这样的能力,我们将引入新的模型评估指标:混淆矩阵和ROC曲线。 上面是混淆矩阵。接下来我们结合图像解释一下准确率&#…

CSS 文字溢出省略号显示

1. 单行文本溢出显示省略号 需要满足三个条件,添加对应的代码: (1)先强制一行内显示文本; (2)超出的部分隐藏; (3)文字用省略号来替代省略的部分&#xf…

Python+reuqests自动化接口测试

1.最近自己在摸索Pythonreuqests自动化接口测试,要实现某个功能,首先自己得有清晰的逻辑思路!这样效率才会很快! 思路--1.通过python读取Excel中的接口用例,2.通过python的函数调用,get/Post 进行测试&…

制造企业如何做好进销存管理工作?

本文你将了解:什么是进销存管理系统?国内制造信息化的发展现状如何?进销存管理系统的功能有哪些? 接下来搭建进销存管理系统教学中用到的图片和系统都来自简道云的进销存管理系统 这也是我们公司目前正在用的进销存管理系统&…

2023.11.10联测总结

T 1 T1 T1求的是有多少个区间的异或和是 k k k的因子, n , k ≤ 1 0 5 n,k \leq 10^5 n,k≤105。 这道题用前缀和维护一下,暴力枚举所有区间就有 80 80 80分。 有一瞬间想过枚举因数,但是脑抽以为要 O ( n ) \mathcal O(n) O(n)枚举&#x…

Python最基础的五个部分代码,零基础也能轻松看懂。

文章目录 前言一、表达式二、赋值语句三、引用四、分支语句五、循环语句关于Python技术储备一、Python所有方向的学习路线二、Python基础学习视频三、精品Python学习书籍四、Python工具包项目源码合集①Python工具包②Python实战案例③Python小游戏源码五、面试资料六、Python兼…

大数据-之LibrA数据库系统告警处理(ALM-12036 license文件即将过期)

告警解释 系统每天零点检查一次当前系统中的license文件,如果当前时间距离过期时间不足60天,则license文件即将过期,产生该告警。 当重新导入一个正常license,告警恢复。 说明: 如果当前集群使用节点数小于等于10节…

软件测试之测试分类(按照测试对象分类,按照测试对象划分)

目录 按照测试对象分类 1.可靠性测试 2.容错性测试 3.安装卸载测试 4.内存泄漏测试 5.弱网测试 按照是否查看代码划分 面试题:那种测试方法用到最多? 按照测试对象分类 关于测试对象分类中的各个测试,在此前已经发表过了&#xff0c…

面试字节测开岗失败后,被面试官在朋友圈吐槽了......(心累)

在和朋友吃夜宵的时候,朋友向我吐槽说自己在参加某大厂测试面试的时候被面试官怼得哑口无言,场面让他一度十分尴尬 印象最深的就是下面几个问题: 根据你以前的工作经验和学习到的测试技术,说说你对质量保证的理解? 非…

楼宇天台视频AI智能监管方案,时刻保障居民安全

一、背景需求分析 我们经常能看到这样的新闻报道,小孩登上小区的天台玩耍,因为家长和物业人员发现得晚,没有及时制止,结果导致意外事故的发生。此前,在某小区就有居民拍下多名儿童在小区高层住宅的楼顶玩耍跳跃&#…