0

0

如何将一个按 start 升序排列的数组进行合并,合并条件为 start 和 end 连续且 content 包含相同项?

碧海醫心

碧海醫心

发布时间:2024-11-15 21:09:46

|

700人浏览过

|

来源于php中文网

原创

如何将一个按 start 升序排列的数组进行合并,合并条件为 start 和 end 连续且 content 包含相同项?

提取连续相同项合并算法问题

给定一个按 start 升序排列的数组,其中每个元素包含 start、end 和 content。目标是提取出连续且相同的项,合并为一个新的对象并插入原数组中。合并的条件是 start 和 end 连续。

示例

输入:

万彩商图
万彩商图

专为电商打造的AI商拍工具,快速生成多样化的高质量商品图和模特图,助力商家节省成本,解决素材生产难、产图速度慢、场地设备拍摄等问题。

下载
[
    { "start": 1, "end": 2, "content": [ "a", "b", "e" ] },    //0
    { "start": 2, "end": 3, "content": [ "b", "c" ] },        //1
    { "start": 3, "end": 4, "content": [ "b", "d" ] },        //2
    { "start": 4, "end": 5, "content": [ "d" ] },            //3
    { "start": 7, "end": 8, "content": [ "b" ] },            //4
    { "start": 9, "end": 11, "content": [ "b", "c" ] }        //5
]

输出:

[
    { "start": 1, "end": 2, "content": [ "a", "e" ] },
    { "start": 1, "end": 4, "content": [ "b" ] },
    { "start": 2, "end": 3, "content": [ "c" ] },
    { "start": 3, "end": 5, "content": [ "d" ] },
    { "start": 7, "end": 8, "content": [ "b" ] },
    { "start": 9, "end": 11, "content": [ "b", "c" ] }
]

算法

  1. 遍历原数组,并遍历每个对象的 content 数组。
  2. 如果当前对象的 end 和下一个对象的 start 相等,且下一个对象的 content 数组中包含当前对象的当前项,则合并下一个对象中的当前项并更新 end。
  3. 对于每个合并后的连续项,创建一个新的对象并将其插入原数组。
  4. 根据 start 和 end 重新排序原数组。
  5. 最后,删除 content 长度为 0 的空对象。

实现

let arr = [
    { "start": 1, "end": 2, "content": [ "A", "B", "E" ] },
    { "start": 2, "end": 3, "content": [ "B", "C" ] },
    { "start": 3, "end": 4, "content": [ "B", "D" ] },
    { "start": 4, "end": 5, "content": [ "D" ] },
    { "start": 7, "end": 8, "content": [ "B" ] },
    { "start": 9, "end": 11, "content": [ "B", "C" ] }
]

let obj = {}
let list = arr.reduce((list, item, index, arr) => {
    item.content.forEach(citem => {
        let i = index
        let next, cindex
        while ((next = arr[i + 1]) && arr[i].end === next.start && (cindex = next.content.indexOf(citem)) >= 0) {
            i++
            next.content.splice(cindex, 1)
        }
        let end = arr[i].end
        let key = item.start + '-' + end
        if(!obj[key]){
            list.push(obj[key] = {
                start: item.start,
                end,
                content: [citem]
            })
        }else{
            obj[key].content.push(citem)
        }
    })
    return list
}, [])

console.log(list)

相关专题

更多
页面置换算法
页面置换算法

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

392

2023.08.14

mc.js网页版入口地址大全
mc.js网页版入口地址大全

本专题整合了mc.js网页版入口地址大全以及mc.js1.8.8版本汇总,阅读专题下面的文章了解更多详细内容。

0

2026.01.05

Python lambda详解
Python lambda详解

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

0

2026.01.05

python处理大数据合集
python处理大数据合集

本专题整合了python处理大数据相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.05

大数据专业学习教程
大数据专业学习教程

本专题整合了大数据专业学习相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.05

python设置中文版教程合集
python设置中文版教程合集

本专题整合了python改成中文版相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.05

从零到实战:Python 编程系统入门专题
从零到实战:Python 编程系统入门专题

本专题面向零编程基础及初学者,系统讲解 Python 编程语言的核心知识与实战技巧。内容涵盖 Python 基础语法、数据结构、函数与模块、常用标准库、简单算法思维,以及真实应用场景下的小项目实战。通过循序渐进的学习路径,帮助读者快速建立编程思维,掌握 Python 在数据处理、自动化脚本及日常开发中的实际应用能力,为后续深入学习 Web 开发、数据分析或人工智能打下坚实基础。

10

2026.01.05

php代码编辑器入口汇总
php代码编辑器入口汇总

本文整理了主流PHP代码编辑器的官网入口及在线使用链接,阅读专题下面的文章了解更多详细内容。

51

2026.01.04

php代码编辑器地址汇总
php代码编辑器地址汇总

本文整理了主流PHP代码编辑器的官网入口及在线使用链接,阅读专题下面的文章了解更多详细内容。

0

2026.01.04

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 10.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.8万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

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

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