2705. Compact Object

Difficulty:
Related Topics:
    Similar Questions:

      Problem

      Given an object or array obj, return a compact object. A compact object is the same as the original object, except with keys containing falsy values removed. This operation applies to the object and any nested objects. Arrays are considered objects where the indices are keys. A value is considered falsy when Boolean(value) returns false.

      You may assume the obj is the output of JSON.parse. In other words, it is valid JSON.

      Example 1:

      Input: obj = [null, 0, false, 1]
      Output: [1]
      Explanation: All falsy values have been removed from the array.
      

      Example 2:

      Input: obj = {"a": null, "b": [false, 1]}
      Output: {"b": [1]}
      Explanation: obj["a"] and obj["b"][0] had falsy values and were removed.
      

      Example 3:

      Input: obj = [null, 0, 5, [0], [false, 16]]
      Output: [5, [], [16]]
      Explanation: obj[0], obj[1], obj[3][0], and obj[4][0] were falsy and removed.
      

      Constraints:

      Solution (Javascript)

      /**
       * @param {Object} obj
       * @return {Object}
       */
      var compactObject = function (obj) {
        // These three if statements deal with when obj is not an iterable object
        // Steps 1-3 as described above
        if (obj === null) return null;
        if (Array.isArray(obj)) return obj.filter(Boolean).map(compactObject);
        if (typeof obj !== "object") return obj;
      
        // This for loop deals with when obj is an iterable object
        // Steps 4-5 as described above
        const compacted = {};
        for (const key in obj) {
          let value = compactObject(obj[key]);
          if (Boolean(value)) compacted[key] = value;
        }
      
        return compacted;
      };
      

      Explain:

      nope.

      Complexity: