0

0

如何将扁平的章节数组转换成嵌套的树形结构?

霞舞

霞舞

发布时间:2025-02-28 22:36:10

|

318人浏览过

|

来源于php中文网

原创

如何将扁平的章节数组转换成嵌套的树形结构?

将扁平数组转换为嵌套树形结构:高效算法详解

本文介绍一种高效算法,用于将扁平章节数组转换为嵌套的树形结构。假设章节数组包含levelcontenturl三个属性,分别表示章节层级、内容和URL。目标是根据level字段,将扁平数组转换为层级结构,其中level值较小的章节作为父节点,level值较大的章节作为子节点。

初始数据:

const chapters = [{
  level: '1',
  content: '案例概况010000-170900',
  url: '案例概况010000-170900.html'
},{
  level: '2',
  content: '案例概况010100-170901',
  url: '案例概况010100-170901.html'
},{
  level: '2',
  content: '案例概况010200-170902',
  url: '案例概况010200-170902.html'
},{
  level: '3',
  content: '案例概况010201-170903',
  url: '案例概况010201-170903.html'
},{
  level: '1',
  content: '案例概况020000-170904',
  url: '案例概况020000-170904.html'
},{
  level: '1',
  content: '案例概况030000-170905',
  url: '案例概况030000-170905.html'
},{
  level: '2',
  content: '案例概况030100-170906',
  url: '案例概况030100-170906.html'
}];

目标树形结构:

const tree = [{
  level: '1',
  content: '案例概况010000-170900',
  url: '案例概况010000-170900.html',
  childs: [{
    level: '2',
    content: '案例概况010100-170901',
    url: '案例概况010100-170901.html',
    childs: []
  },{
    level: '2',
    content: '案例概况010200-170902',
    url: '案例概况010200-170902.html',
    childs: [{
      level: '3',
      content: '案例概况010201-170903',
      url: '案例概况010201-170903.html',
      childs: []
    }]
  }]
},{
  level: '1',
  content: '案例概况020000-170904',
  url: '案例概况020000-170904.html',
  childs: []
},{
  level: '1',
  content: '案例概况030000-170905',
  url: '案例概况030000-170905.html',
  childs: [{
    level: '2',
    content: '案例概况030100-170906',
    url: '案例概况030100-170906.html',
    childs: []
  }]
}];

高效算法实现:

Batch GPT
Batch GPT

使用AI批量处理数据、自动执行任务

下载

该算法使用递归的方式,逐层构建树形结构。它首先将扁平数组按照level排序,然后递归地处理每个章节,将其添加到合适的父节点下。 为了提高效率,它避免了多次遍历数组,而是利用Map对象快速查找父节点。

function convertToTree(chapters) {
  // 按照 level 排序
  chapters.sort((a, b) => parseInt(a.level) - parseInt(b.level));

  const tree = [];
  const map = new Map(); // 使用 Map 提高查找效率

  chapters.forEach(chapter => {
    const level = parseInt(chapter.level);
    if (level === 1) {
      tree.push({ ...chapter, childs: [] });
      map.set(chapter.content, tree[tree.length - 1]);
    } else {
      let parent = findParent(map, chapter);
      if (parent) {
        parent.childs.push({ ...chapter, childs: [] });
        map.set(chapter.content, parent.childs[parent.childs.length - 1]);
      }
    }
  });

  return tree;
}

function findParent(map, chapter) {
  let level = parseInt(chapter.level);
  let parentContent = chapter.content.substring(0, chapter.content.length - 2); // 假设父节点的content是子节点content的前缀,需要根据实际情况调整
  while (level > 1) {
    if (map.has(parentContent)) {
      return map.get(parentContent);
    }
    level--;
    parentContent = parentContent.substring(0, parentContent.length - 2);
  }
  return null;
}

const tree = convertToTree(chapters);
console.log(JSON.stringify(tree, null, 2));

这段代码假设父节点的content属性是子节点content属性的前缀(例如,'案例概况010200-170902' 的父节点的content可能是 '案例概况010200-170901' 或 '案例概况010000-170900'),这部分逻辑需要根据实际数据结构进行调整。 如果父子关系并非通过content的前缀来确定,则需要修改findParent函数以匹配实际的父子关系确定方式。

这个改进后的算法在处理大型数组时效率更高,因为它避免了重复的数组遍历,并利用了Map对象的快速查找能力。 记住根据你的实际数据结构调整findParent函数中的父子关系判断逻辑。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

529

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

6

2025.12.22

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

73

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

25

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

36

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

31

2025.11.27

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

387

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

1

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号