美文网首页
Java树形筛选算法

Java树形筛选算法

作者: cyun | 来源:发表于2022-05-07 16:21 被阅读0次

Java树形筛选算法

提示:使用递归方法,个人在项目中有使用到,有问题希望指出:

使用场景:当我们得到一个树形结构数据时,可能需要在树形结构上对数据进行筛选,例如通过文件夹(文件)名称模糊查询相关的文件夹并展现其父级。

缺点:需要查询出完整的树形结构才能用作筛选,在数据量非常庞大的时候并不适用。

一、话不多说直接上代码块

代码如下:

import com.alibaba.fastjson.JSON;
import lombok.Data;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;

@Data
public class TreeDto {

    private String id;
    private String name;
    private List<TreeDto> subsetTreeDtoList;



    public TreeDto(String id,String name,List<TreeDto> subsetTreeDtoList){
        this.id = id;
        this.name = name;
        this.subsetTreeDtoList = subsetTreeDtoList;
    }

    /**
     * 树形筛选查找
     * @param treeDtoList 树形集合
     * @param idList 筛选条件(可以是其他条件)
     * @return 包含的节点数据
     */
    public static List<TreeDto> screenTree(List<TreeDto> treeDtoList, List<String> idList){
        //最后返回的筛选完成的集合
        List<TreeDto> screeningOfCompleteList = new ArrayList<>();
        if (listIsNotEmpty(treeDtoList) && listIsNotEmpty(idList)){
            for (TreeDto treeDto : treeDtoList){
                List<TreeDto> subsetList = treeDto.getSubsetTreeDtoList();
                //递归筛选完成后的返回的需要添加的数据
                TreeDto addTreeDto = getSubsetPmsPlanPo(treeDto,subsetList,idList);
                if (isNotEmpty(addTreeDto)){
                    screeningOfCompleteList.add(addTreeDto);
                }
            }
            return screeningOfCompleteList;
        }
        return null;
    }


    /**
     * 筛选符合的集合并返回
     * @param treeDto 树形类
     * @param subsetTreeDtoList 子集集合
     * @param idList 筛选条件
     * @return 筛选成功的类
     */
    public static TreeDto getSubsetPmsPlanPo(TreeDto treeDto,List<TreeDto> subsetTreeDtoList,List<String> idList){
        //作为筛选条件的判断值
        String id = treeDto.getId();
        //有子集时继续向下寻找
        if (listIsNotEmpty(subsetTreeDtoList)){
            List<TreeDto> addTreeDtoList = new ArrayList<>();
            for (TreeDto subsetTreeDto : subsetTreeDtoList){
                List<TreeDto> subsetList = subsetTreeDto.getSubsetTreeDtoList();
                TreeDto newTreeDto = getSubsetPmsPlanPo(subsetTreeDto,subsetList,idList);
                //当子集筛选完不为空时添加
                if (isNotEmpty(newTreeDto)){
                    addTreeDtoList.add(newTreeDto);
                }
            }
            //子集满足条件筛选时集合不为空时,替换对象集合内容并返回当前对象
            if (listIsNotEmpty(addTreeDtoList)){
                treeDto.setSubsetTreeDtoList(addTreeDtoList);
                return treeDto;
                //当前对象子集对象不满足条件时,判断当前对象自己是否满足筛选条件,满足设置子集集合为空,并返回当前对象
            }else if (listIsEmpty(addTreeDtoList) && idList.contains(id)){
                treeDto.setSubsetTreeDtoList(null);
                return treeDto;
            }else {
                //未满足筛选条件直接返回null
                return null;
            }
        }else {
            //无子集时判断当前对象是否满足筛选条件
            if (idList.contains(id)){
                return treeDto;
            }else {
                return null;
            }
        }
    }

    /**
     * 判断集合为空
     * @param list 需要判断的集合
     * @return 集合为空时返回 true
     */
    public static boolean listIsEmpty(Collection list){
        return  (null == list || list.size() == 0);
    }

    /**
     * 判断集合非空
     * @param list 需要判断的集合
     * @return 集合非空时返回 true
     */
    public static boolean listIsNotEmpty(Collection list){
        return !listIsEmpty(list);
    }

    /**
     * 判断对象为null或空时
     * @param object 对象
     * @return 对象为空或null时返回 true
     */
    public static boolean isEmpty(Object object) {
        if (object == null) {
            return (true);
        }
        if ("".equals(object)) {
            return (true);
        }
        if ("null".equals(object)) {
            return (true);
        }
        return (false);
    }

    /**
     * 判断对象非空
     * @param object 对象
     * @return 对象为非空时返回 true
     */
    public static boolean isNotEmpty(Object object) {
        if (object != null && !object.equals("") && !object.equals("null")) {
            return (true);
        }
        return (false);
    }

    public static void main(String[] args) {
        TreeDto treeDto1 = new TreeDto("1","A",new ArrayList<TreeDto>());
        TreeDto treeDto1_1 = new TreeDto("1.1","A-A",new ArrayList<TreeDto>());
        TreeDto treeDto1_2 = new TreeDto("1.2","A-B",new ArrayList<TreeDto>());
        TreeDto treeDto1_3 = new TreeDto("1.3","A-C",new ArrayList<TreeDto>());
        treeDto1.getSubsetTreeDtoList().add(treeDto1_1);
        treeDto1.getSubsetTreeDtoList().add(treeDto1_2);
        treeDto1.getSubsetTreeDtoList().add(treeDto1_3);

        TreeDto treeDto2 = new TreeDto("2","B",new ArrayList<TreeDto>());
        TreeDto treeDto2_1 = new TreeDto("2.1","B-A",new ArrayList<TreeDto>());
        TreeDto treeDto2_2 = new TreeDto("2.2","B-B",new ArrayList<TreeDto>());
        TreeDto treeDto2_3 = new TreeDto("2.3","B-C",new ArrayList<TreeDto>());
        TreeDto treeDto2_3_1 = new TreeDto("2.3.1","B-C-A",null);
        treeDto2.getSubsetTreeDtoList().add(treeDto2_1);
        treeDto2.getSubsetTreeDtoList().add(treeDto2_2);
        treeDto2.getSubsetTreeDtoList().add(treeDto2_3);
        treeDto2.getSubsetTreeDtoList().get(2).getSubsetTreeDtoList().add(treeDto2_3_1);

        String[] array = {"1.3","2.2","2.3.1"};
        List<String> idList = Arrays.asList(array);
        List<TreeDto> treeDtoList = new ArrayList<>();
        treeDtoList.add(treeDto1);
        treeDtoList.add(treeDto2);
        System.out.println(JSON.toJSONString(screenTree(treeDtoList,idList)));
    }
}

二、返回结果如下图

image.png

相关文章

  • Java树形筛选算法

    Java树形筛选算法 提示:使用递归方法,个人在项目中有使用到,有问题希望指出: 使用场景:当我们得到一个树形结构...

  • 【恋上数据结构与算法一】(六)二叉树

    二叉树 线性结构 树形结构 二叉树 多叉树 生活中的树形结构 ◼ 使用树形结构可以大大提高效率◼ 树形结构是算法面...

  • 数据结构与算法

    参考链接:算法 数据结构与算法 iOS数据结构 和 算法 上 算法 1、数据结构: 集合结构: 线性结构: 树形结...

  • ML-决策树(Decision Tress)

    决策树是一种用于分类和回归任务的 非参数监督学习算法。该算法在于基于训练数据生成一个树形的决策结构。树形的决策结构...

  • 数据挖掘-决策树算法

    决策树算法是一种比较简易的监督学习分类算法,既然叫做决策树,那么首先他是一个树形结构,简单写一下树形结构(数据结构...

  • java 树形结构

    树实体类 树结构排序工具类 测试类 输出结果

  • 树形结构作为条件筛选条件

    一级货位、二级货位、三级货位 根据旁边树形 TreeView不分级别加载的情况货位信息分一、二、三级 最上级为库区...

  • 树形结构算法实现

    要求 现在有这样的数据结构 需要得出像树形结构的数据 实现算法 结果image.png

  • 数据结构与算法 - 树形结构

    数据结构与算法系列文章数据结构与算法 - 时间复杂度数据结构与算法 - 线性表数据结构与算法 - 树形结构 目录 ...

  • 数据结构&算法(一)

    一、Java实现快速排序算法 二、Java实现折半插入排序算法 三、Java实现冒泡排序算法

网友评论

      本文标题:Java树形筛选算法

      本文链接:https://www.haomeiwen.com/subject/yidxurtx.html