2705. 精简对象

简介: 2705. 精简对象

说在前面

🎈不知道大家对于算法的学习是一个怎样的心态呢?为了面试还是因为兴趣?不管是出于什么原因,算法学习需要持续保持。

题目描述

现给定一个对象或数组 obj,返回一个 精简对象精简对象 与原始对象相同,只是将包含 值的键移除。该操作适用于对象及其嵌套对象。数组被视为索引作为键的对象。当 Boolean(value) 返回 false 时,值被视为 值。

你可以假设 objJSON.parse 的输出结果。换句话说,它是有效的 JSON。

示例 1:

输入: obj = [null, 0, false, 1]
输出: [1]
解释: 数组中的所有假值已被移除。

示例 2:

输入: obj = {"a": null, "b": [false, 1]}
输出: {"b": [1]}
解释: obj["a"] 和 obj["b"][0] 包含假值,因此被移除。

示例 3:

输入: obj = [null, 0, 5, [0], [false, 16]]
输出: [5, [], [16]]
解释: obj[0], obj[1], obj[3][0], 和 obj[4][0] 包含假值,因此被移除。

提示:

  • obj 是一个有效的 JSON 对象
  • 2 <= JSON.stringify(obj).length <= 10^6

解题思路

首先,代码检查传入的参数是否为数组。如果是数组,就使用 reduce 方法对数组进行迭代。在每次迭代中,首先检查当前项 item 是否存在(非 null、undefined 或空值)。如果存在,进一步判断 item 的类型是否为对象。如果是对象,则递归调用 compactObject 函数对其进行紧凑处理,并将结果加入到结果数组 acc 中。如果 item 不是对象,则直接将其加入到结果数组中。最后,返回紧凑处理后的结果数组。

如果传入的参数不是数组,则假定它是一个对象。代码通过 Object.entries 方法将对象转换为一个键值对数组,并使用 reduce 方法对键值对数组进行迭代。在每次迭代中,首先检查当前值 value 是否存在(非 null、undefined 或空值)。如果存在,进一步判断 value 的类型是否为对象。如果是对象,则递归调用 compactObject 函数对其进行紧凑处理,并将结果赋值给结果对象 acc 的相应键 key。如果 value 不是对象,则直接将其赋值给结果对象的相应键。最后,返回紧凑处理后的结果对象。

AC代码

/**
 * @param {Object|Array} obj
 * @return {Object|Array}
 */
var compactObject = function (obj) {
  if (Array.isArray(obj)) {
    return obj.reduce((acc, item) => {
      if (item) {
        if (typeof item === "object") {
          const tmp = compactObject(item);
          acc.push(tmp);
        } else {
          acc.push(item);
        }
      }
      return acc;
    }, []);
  } else {
    return Object.entries(obj).reduce((acc, [key, value]) => {
      if (value) {
        if (typeof value === "object") {
          const tmp = compactObject(value);
          acc[key] = tmp;
        } else {
          acc[key] = value;
        }
      }
      return acc;
    }, {});
  }
};

公众号

关注公众号『前端也能这么有趣』,获取更多有趣内容。

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

目录
相关文章
|
17天前
|
安全 算法 测试技术
静态代码分析的这些好处,我竟然都不知道?
软件开发中,单元测试确保模块功能,但静态代码分析是质量保证的关键。静态分析检查代码结构,发现潜在错误,补充单元测试的不足。虽然静态分析工具不能替代人工验证,它们在识别复杂逻辑错误和提升代码质量方面至关重要。结合单元测试和静态分析能提高代码安全性与整体质量,减少后期问题,降低成本。SonarQube等工具简化了静态分析过程,强调早期错误检测的重要性。
|
7天前
|
JavaScript 前端开发
JavaScript模块化将复杂软件分解为独立模块,提高代码可读、维护、复用和扩展性。
【6月更文挑战第27天】模块化将复杂软件分解为独立模块,提高代码可读、维护、复用和扩展性。JavaScript模块化有CommonJS(Node.js,`require()`/`module.exports`)、AMD(RequireJS,异步,`define()`/`require()`)和ES6 Modules(官方标准,`import`/`export`)。打包工具如Webpack、Rollup处理兼容性,使模块能在不同环境中运行。
12 0
|
2月前
|
JavaScript 前端开发 测试技术
编写JavaScript模块化代码主要涉及将代码分割成不同的文件或模块,每个模块负责处理特定的功能或任务
【5月更文挑战第10天】编写JavaScript模块化代码最佳实践:使用ES6模块或CommonJS(Node.js),组织逻辑相关模块,避免全局变量,封装细节。利用命名空间和目录结构,借助Webpack处理浏览器环境的模块。编写文档和注释,编写单元测试以确保代码质量。通过这些方法提升代码的可读性和可维护性。
28 3
|
10月前
|
设计模式 传感器 API
在编写RTOS代码时,如何设计一个简单、优雅、可拓展的任务初始化结构?
在编写RTOS代码时,如何设计一个简单、优雅、可拓展的任务初始化结构?
106 0
|
编译器
由编译器特别支持的包装
由编译器特别支持的包装
55 0
|
存储 负载均衡 Oracle
面向(过程、对象、组件、服务)编程
面向(过程、对象、组件、服务)编程
261 0
【自然框架】内部类库、控件的引用关系(最新整理,基本稳定)
  和以前相比,减少了一个项目,把Control_Interface合并到CommonFunction里面。这样引用关系就简单多了。   基本上分为三个层次:类库、自定义控件、页面基类。其中的 MetaData 负责元数据的定义和加载。
632 0
|
Go C# 图形学
Unity3D中对系统类进行扩展教程(简化代码逻辑)
Unity中对系统类进行扩展的方法 Unity扩展系统类,简化代码 本文提供全流程,中文翻译。 助力快速完成 Unity 对系统类进行扩展,添加函 新建一个脚本,名称随意 类必须设为静态 Static ,函数同样(这样才能通过其他类,直接访问到扩展函数) 形参为 this + 需要扩展的类 此时,我们通过 transform.
1460 0
|
C# 数据格式 JSON
(转)C# 快速高效率复制对象的方式
1、需求 在项目代码中经常需要把对象复制到新的对象中,或者把属性名相同的值复制一遍。 比如: public class Student { public int Id { get; set; } public string Name...
3545 0

热门文章

最新文章