一道编程题

package com.example.demo;

import org.springframework.util.CollectionUtils;

import java.util.ArrayList;
import java.util.List;

public class DepartmentTest {
        public static void main(String[] args) {
                List<Department> allDepartment = new ArrayList<>();
                Department dep1 = new Department(1, 0, "北京总部");
                Department dep3 = new Department(3, 1, "研发中心");
                Department dep4 = new Department(4, 3, "后端研发组");
                Department dep6 = new Department(6, 4, "后端实习生组");
                Department dep7 = new Department(7, 3, "前端研发组");
                Department dep8 = new Department(8, 1, "产品部");

                allDepartment.add(dep6);
                allDepartment.add(dep7);
                allDepartment.add(dep8);
                allDepartment.add(dep1);
                allDepartment.add(dep3);
                allDepartment.add(dep4);


            List<Department> subDepartments = DepartmentTest.getSub(3, allDepartment);
            for (Department subDepartment : subDepartments) {
                System.out.println(subDepartment);
            }
      }
      /**
       * 根据id,获取所有子部门列表(包括隔代子部门,一直到叶子节点)
       * 要求:不能新增参数,不能增加static变量
       * @param pid
       * @return
       */
        public static List<Department> getSub(int pid, List<Department> allDepartment) {
            return getSubList(pid, allDepartment);
        }

        public static List<Department> getSubList(int pid, List<Department> allDepartment){

            List<Department> subDepartment = new ArrayList<>();

            for (Department department  : allDepartment ) {
                if(department.getPid() == pid){
                    subDepartment.add(department);
                }
            }

            if(CollectionUtils.isEmpty(subDepartment)){
                return subDepartment;
            }

            for (Department department  : allDepartment ) {
                if(department.getPid() == pid){
                    List<Department> subList = getSubList(department.getId(), allDepartment);
                    subDepartment.addAll(subList);
                }
            }
            return subDepartment;
        }


  }
  class Department {
      /** id */
      private int id;
      /** parent id */
      private int pid;
      /** 名称 */
      private String name;
      public Department(int id, int pid, String name) {
          this.id = id;
          this.pid = pid;
          this.name = name;
      }
      public int getId() {
          return id;
      }
      public void setId(int id) {
          this.id = id;
      }
      public int getPid() {
          return pid;
      }
      public void setPid(int pid) {
          this.pid = pid;
      }
      public String getName() {
          return name;
      }
      public void setName(String name) {
          this.name = name;
      }
      @Override
      public String toString() {
          return "Department{" +
                  "id=" + id +
                  ", pid=" + pid +
                  ", name='" + name + '\'' +
                  '}';
      }
  }
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容