当前位置: 首页 > news >正文

聊城手机网站制作网络销售真恶心

聊城手机网站制作,网络销售真恶心,婚恋交友网站开发,项目管理工具目录 一、前言二、具体实现及拓展2.1、递归-目标节点到根节点的路径数据2.2、list转换为tree结构2.3、tree转换为list结构 一、前言 这么多年工作经历中,“数据结构和算法”真的是超重要,工作中很多业务都能抽象成某种数据结构问题。下面是项目中遇到的…

目录

  • 一、前言
  • 二、具体实现及拓展
    • 2.1、递归-目标节点到根节点的路径数据
    • 2.2、list转换为tree结构
    • 2.3、tree转换为list结构

一、前言

这么多年工作经历中,“数据结构和算法”真的是超重要,工作中很多业务都能抽象成某种数据结构问题。下面是项目中遇到的一个问题。
业务背景:
在一个复杂的N叉树目录上,通过模糊搜索只返回搜索到的【要返回完整的从root到目标节点】节点链路,以便外围系统直接使用
分析:
按照实际操作,模糊搜索只能搜索到需要的几个目标节点数据,但实际业务需要的是这些目标节点到根节点的结构,以便完美展示。
在这里插入图片描述

问题抽象:
N叉树中,找到所有目标节点到根节点的数据,并构建成tree结构返回。如下图,要返回这些目标节点到根节点的整个路径上的节点数据。
在这里插入图片描述

二、具体实现及拓展

完整的代码如下

 public void filterNodeFromTree(){//查询所有的【"有树形结构的"】列表数据List<NodeTreeDo> originList = new ArrayList<>();Map<String,NodeTreeDo> originMap = originList.stream().collect(Collectors.toMap(NodeTreeDo::getId,ma->ma));//目标节点idList<String> targetIds = new ArrayList<>();Set<String> curRootIdSet = new HashSet<>(); //收集某个目标节点到root的路径经过的所有节点for(String id : targetIds){if(curRootIdSet.contains(id)) continue;//已经经历过路径,跳过curRootIdSet.addAll(collectNeedNode(originMap,id));}//收集到所有需要的节点的id,然后在过滤多余的List<NodeTreeDo> needList = originList.stream().filter(k->curRootIdSet.contains(k.getId())).collect(Collectors.toList());//构建成treelistToTree(needList);}

2.1、递归-目标节点到根节点的路径数据

private Set<String> collectNeedNode(Map<String,NodeTreeDo> originMap,String targetId){Set<String> idResultSet = new HashSet<>();collectNeedNode(originMap,targetId,idResultSet);return idResultSet;}private boolean collectNeedNode(Map<String,NodeTreeDo> originMap,String targetId,Set<String> idSet){if(!originMap.containsKey(targetId)) return false;idSet.add(targetId);NodeTreeDo cur = originMap.get(targetId);return collectNeedNode(originMap,cur.getParentId(),idSet);}

2.2、list转换为tree结构

    private List<NodeTreeDo> listToTree(List<NodeTreeDo> originList){Map<String, List<NodeTreeDo>> nodeByPidMap = originList.stream().collect(Collectors.groupingBy(NodeTreeDo::getParentId));// 循环一次设置当前节点的子节点originList.forEach(node -> node.setChildren(nodeByPidMap.get(node.getId())));// 获取 一级列表return originList.stream().filter(k->"".equals(k.getParentId())).collect(Collectors.toList());}

2.3、tree转换为list结构

  private List<NodeTreeDo> treeToList(List<NodeTreeDo> treeList){List<NodeTreeDo> resultList = new ArrayList<>();for(NodeTreeDo node : treeList){getAllListFromChildren(node,resultList);}return resultList;}private void getAllListFromChildren(NodeTreeDo node,List<NodeTreeDo> resultList){NodeTreeDo copy = CommonUtil.transForm(node,NodeTreeDo.class);copy.setChildren(null); //深度拷贝后,把children设置为nullresultList.add(copy);if(CollectionUtils.isNotEmpty(node.getChildren())){for(NodeTreeDo temp : node.getChildren()){getAllListFromChildren(temp,resultList);}}//没子节点了,自动会退出}
http://www.ds6.com.cn/news/7161.html

相关文章:

  • 石家庄网站排名推广吉林百度seo公司
  • 网站运营和管理电商运营多少钱一个月
  • 宿舍网页设计html模板seo关键词找29火星软件
  • 网站建设怎么报印花税seo编辑招聘
  • 做游戏网站的分析千锋教育前端学费多少
  • 东莞 营销网站建设游戏推广员平台
  • 网站做外链软件百度知道首页登录
  • 做暧昧的小视频网站2台州seo排名公司
  • dw网站开发环境优秀的网页设计网站
  • 宁德网站推广杭州推广公司排名
  • 网页设计与制作怎么把图片加进去seo关键词排名优化怎么样
  • perl 动态网站开发广州抖音推广公司
  • 网站前端做报名框创建自己的网站
  • 私人做网站收费g3云推广
  • 做门户网站广告市场调研怎么做
  • 南通做网站的公司推广策略怎么写
  • 网站怎么做自适应政府免费培训 面点班
  • 正规的h5网站宁波seo排名外包
  • 得到app公司广州seo排名优化服务
  • 毕业设计做音乐网站可以吗百度收录时间
  • 怎么做像表白墙的网站软文范例200字
  • 教做黏土手工的网站淘宝交易指数换算工具
  • 做网站设计师的感想实事新闻热点
  • wordpress导航图标代码关键词优化排名软件s
  • 辽宁省和城乡建设厅网站网络营销理论
  • 网站开发入门书籍推荐人际网络营销2900
  • 宁波网站建设设计制作方案与价格seopeix
  • 赣州网红打卡旅游景点百度快速优化排名软件
  • 网站首页鲁大师广告投放平台都有哪些
  • 网站关键词推广上海百度搜索排名优化