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

9.22(一):数组扁平化

ES6的flat方法

const arr=[1,2,[33,44,5,[6,7]],3]// es6中的flat方法function arr1()
{
//数组自带的扁平化方法,flat的参数代表的是需要展开几层,
//如果是Infinity的话,就是不管嵌套几层,全部都展开return arr.flat(Infinity)
}
let result=arr1();
console.log(result)

结果:
在这里插入图片描述

JSON+正则

function arr2()
{
//  首先是使用 JSON.stringify 把 arr 转为字符串
// 接着使用正则把字符串里面的 [ 和 ] 去掉
// 然后再拼接数组括号转为数组对象let arr1=JSON.stringify(arr).replace(/\[|\]/g,"");return JSON.parse('['+arr1+']')
}

结果:
在这里插入图片描述

递归

function arr3() {let myArr = [];function fn(arr1){for (let i = 0; i < arr1.length; i++) {//判断是否是数组if(Array.isArray(arr1[i])){fn(arr1[i])}else{myArr.push(arr1[i])}}}fn(arr)return myArr
}

结果:
在这里插入图片描述

reduce方法

function myredduce(arr)
{// reduce 方法: 可以用来给数组求和
// concat() 方法用于连接两个或多个数组。
// concat() 方法不会更改现有数组,而是返回一个新数组,其中包含已连接数组的值。return arr.reduce((pre,cur)=>{return pre.concat(Array.isArray(cur) ? myredduce(cur) : cur)},[])}
let result = myredduce(arr);

结果:
在这里插入图片描述

栈思想

function mystack()
{let newArr=[];let stack=[].concat(arr)while(stack.length!=0){const val=stack.pop();if(Array.isArray(val)){stack.push(...val)}else{newArr.unshift(val)}}return newArr
}
let result = mystack(arr);

结果:
在这里插入图片描述

http://www.lryc.cn/news/172852.html

相关文章:

  • 【vue2第十九章】手动修改ESlint错误 和 配置自动化修改ESlint错误
  • 计算机网络常见面试题
  • springboot整合MeiliSearch轻量级搜索引擎
  • 禁用鼠标的侧边按键
  • 【C语言】数组和指针刷题练习
  • 2023年中国研究生数学建模竞赛D题解题思路
  • 在编译源码的环境下,搭建起Discuz!社区论坛和WordPress博客的LNMP架构
  • 腾讯面试题:无网络环境,如何部署Docker镜像?
  • 医学影像信息(PACS)系统软件源码
  • 【01】FISCOBCOS的系统环境安装
  • flutter 权限和图片权限之前的冲突
  • OpenCV(四十八):读取视频和保存视频
  • 如何在react/next.js app中的同级组件间传递数据
  • 软件需求文档、设计文档、开发文档、运维文档大全
  • 排序算法-----归并排序
  • docker 配置 gpu版pytorch环境--部署缺陷检测--Anomalib
  • 为什么定时发朋友圈会更有效呢?
  • 【跟小嘉学 PHP 程序设计】一、PHP 开发环境搭建
  • 【zookeeper】zk选举、使用与三种节点简介,以及基于redis分布式锁的缺点的讨论
  • Unity截图生成图片 图片生成器 一键生成图片
  • Matlab图像处理-区域特征
  • golang 自动生成文件头
  • Excel中的宏、VBA
  • 2023华为杯数学建模研赛思路分享——最全版本A题深度解析
  • 【校招VIP】测试方案之测试需求分析
  • 滚珠螺母的清洁方式
  • leetcode做题笔记148. 排序链表
  • 多线程学习
  • 软件测试/测试开发丨ChatGPT在测试计划中的应用策略
  • 链表oj3(Leetcode)——相交链表;环形链表