首先需要理解集合 根节点和子节点的概念

  • 以下是代码,建议自己手敲一遍加深理解,学会类比
  1. Staff类

public abstract class Staff {
    // 员工号
    protected String no;
    // 职工名字
    protected String name;
    // 职位
    protected String position;
    // 薪资
    protected float salary;
    // 私有属性 长度字符串
    private int length;
    // 构造方法
    public Staff(String no, String name, String position, float salary) {
        this.no = no;
        this.name = name;
        this.position = position;
        this.salary = salary;
        // 计算总字节长度
        this.length += (no == null || "".equals(no.trim())) ? 0
                : no.getBytes().length;
        this.length += (name == null || "".equals(name.trim())) ? 0 : name
                .getBytes().length;
        this.length += (position == null || "".equals(position.trim())) ? 0
                : position.getBytes().length;
        this.length += String.valueOf(salary).getBytes().length;
    }
    // 获得用户基本信息
    public void printUserBaseInfo() {
        System.out.println("|" + this.no + " " + this.name + " "
                + this.position + " " + this.salary);
    }
    // 添加员工信息
    public abstract void add(Staff staff);
    // 删除员工
    public abstract Staff remove(String no);
    // 打印员工信息
    public abstract void printEmployeesInfo(int layer);
    // 打印若干字符
    protected void printChar(int layer) {
        for (int j = 0; j < layer * 2; j++) {
            System.out.print("-");
        }
    }
    // 私有方法打印一行
    protected void printLine() {
        System.out.print("+");
        for (int i = 0; i < this.length + 4; i++) {
            System.out.print("-");
        }
        System.out.println("-");
    }
    public String getNo() {
        return no;
    }
    public void setNo(String no) {
        this.no = no;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPosition() {
        return position;
    }
    public void setPosition(String position) {
        this.position = position;
    }
    public float getSalary() {
        return salary;
    }
    public void setSalary(float salary) {
        this.salary = salary;
    }
}


  1. Employees类

public class Employees extends Staff{
    // 构造方法
    public Employees(String no, String name, String position, float salary)
    {
        super(no, name, position, salary);
    }
    /**
     * 添加员工信息
     */
    @Override
    public void add(Staff staff)
    {
        return;
    }
    /**
     * 删除员工信息
     */
    @Override
    public Staff remove(String no)
    {
        // 直接返回null
        return null;
    }
    /**
     * 打印员工信息
     */
    @Override
    public void printEmployeesInfo(int layer)
    {
        return;
    }
}


  1. Manage类
import java.util.ArrayList;

public class Manager extends Staff {
    // 存储手下员工信息
    private final ArrayList<Staff> arrayList = new ArrayList<Staff>();
    // 构造方法
    public Manager(String no, String name, String position, float salary) {
        super(no, name, position, salary);
    }
    /**
     * 增加一个员工
     */
    @Override
    public void add(Staff staff) {
        this.arrayList.add(staff);
    }
    /**
     * 删除员工信息
     */
    @Override
    public Staff remove(String no) {
        Staff staff = null;
        if (no != null && !"".equals(no.trim())) {
            for (int i = 0; i < this.arrayList.size(); i++) {
                if (this.arrayList.get(i) == null) {
                    continue;
                }
                if (no.equals(this.arrayList.get(i).getNo())) {
                    staff = this.arrayList.remove(i);
                    break;
                }
            }
        }
        return staff;
    }
    /**
     * 打印员工信息
     */
    @Override
    public void printEmployeesInfo(int layer) {
        int tmpLayer = ++layer;
        for (int i = 0; i < this.arrayList.size(); i++) {
            if (this.arrayList.get(i) == null) {
                continue;
            }
            // 打印'-'
            printChar(tmpLayer);
            // 打印员工基本信息
            this.arrayList.get(i).printUserBaseInfo();
            // 打印手下员工信息
            this.arrayList.get(i).printEmployeesInfo(tmpLayer);
        }
    }
}


  1. Client测试类
public class Client {
    /**
     * @param args
     */
    public static void main(String[] args)
    {
        // 公司CEO
        Staff boss = new Manager("1", "大老板", "CEO", 100000);
        /**
         * CEO手下有若干部门经理
         */
        // 财务部经理
        Staff financeManager = new Manager("11", "张总", "财务部经理", 60000);
        // 人事部经理
        Staff personnelManager = new Manager("12", "王总", "人事部经理", 60000);
        // 技术部经理
        Staff technicalManager = new Manager("13", "陈总", "技术部经理", 60000);
        /**
         * 技术部门还有助理和若干主管
         */
        // 技术部门助理
        Staff deptAssistant = new Manager("1301", "王助理", "部门助理", 20000);
        // 技术部门主管1
        Staff deptManager1 = new Manager("1302", "主管1", "技术主管", 30000);
        /**
         * 技术主管deptManager1 下面还有软件工程师(最终干活的人)
         */
        Staff softwareEngineer1 = new Employees("1302001", "张三", "软件工程师", 5000);
        Staff softwareEngineer2 = new Employees("1302002", "李四", "软件工程师", 5500);
        Staff softwareEngineer3 = new Employees("1302003", "王五", "软件工程师", 4500);
        // 为技术主管1添加员工信息
        deptManager1.add(softwareEngineer1);
        deptManager1.add(softwareEngineer2);
        deptManager1.add(softwareEngineer3);
        // 技术部门主管2
        Staff deptManager2 = new Manager("1303", "主管2", "技术主管", 30000);
        // 为技术部经理 添加:部门助理、技术主管1和技术主管2
        technicalManager.add(deptAssistant);
        technicalManager.add(deptManager1);
        technicalManager.add(deptManager2);
        // 市场部经理
        Staff marketingManager = new Manager("14", "吴总", "市场部经理", 60000);
        // 为CEO 添加:财务部经理、人事部经理、技术部经理和市场部经理
        boss.add(financeManager);
        boss.add(personnelManager);
        boss.add(technicalManager);
        boss.add(marketingManager);
        // 打印CEO 信息
        boss.printUserBaseInfo();
        // 打印CEO 手下员工信息
        boss.printEmployeesInfo(1);
    }
}


以上代码会跑出以下的结果:

java 树形结构的对象copy java 树形结构 代码_jvm

补一句  理解挂值的思想:


TreeNode treeA = new TreeNode("A");
treeA.add(new TreeNode("B"));
treeA.add(new TreeNode("C"));

TreeNode treeNodeD = new TreeNode("D");
treeNodeD.add(new TreeNode("D1"));
treeNodeD.add(new TreeNode("D2"));
treeA.add(treeNodeD);
print(treeA);


这里面是把A放在根节点,在A的基础上新增加子节点B、C,

treeA.add(treeNodeD) ;这一句是将D挂在A的根节点上这样,就相当于A根节点下有A、B、C三个根节点,将D1、D2挂在D下面,这样就形成了三层。