Mark As Completed Discussion

Good morning! Here's our prompt for today.

Given an array of positive and negative integers like the following:

JAVASCRIPT
1const arr = [3, 5, -2, -4, 7, -1, 6, 8, -8, 4];

Can you write a method findSumZeroSubsets to return the starting and ending indexes of all subarrays in it that sum up to zero?

Note: There are 3 terms that you should be able to distinguish when in the context of arrays. Those are:

  1. Subset: A subset of an array is what it says exactly, a piece of a larger set. It is not ordered and not contiguous. Bear in mind that there can be empty subsets of an array.
  2. Subsequence: A subsequence is a non-empty subset that maintains the order of the elements according to the original array.
  3. Subarray: A non-empty subset of an array that is contiguous.

Note that in this challenge, we are using the terms subset and subarray interchangeable, but are always referring to the definition of contiguous subarray.

Let's take the following example for the original problem:

Description
JAVASCRIPT
1let arr = [3, 5, -2, -4, 7, -1, 6, 8, -8, 4]
2findSumZeroSubsets(arr);
3// [[2, 5], [7, 8]]
4// From 2 to 5
5// From 7 to 8

We log out From 2 to 5 because from index 2 to 5, the elements are [-2, -4, 7, -1], which sum up to 0. Similarly, indices 7 and 8 are 8 and -8 respectively, which also sum up to 0. Here's another example:

JAVASCRIPT
1arr = [4, -5, 1, -3, 2, -8, 5, -2, 9]
2findSumZeroSubsets(arr);
3// [[0, 2], [2, 4]]
4// From 0 to 2
5// From 2 to 4

Constraints

  • Length of the array <= 100000
  • The array will contain values between -1000 and 1000
  • Expected time complexity: O(n)
  • Expected space complexity: O(n)

Try to solve this here or in Interactive Mode.

How do I practice this challenge?

JAVASCRIPT
OUTPUT
:001 > Cmd/Ctrl-Enter to run, Cmd/Ctrl-/ to comment

Here's a video of us explaining the solution.

To change the speed of the video or see it in full screen, click the icons to the right of the progress bar.

Here's our guided, illustrated walk-through.

How do I use this guide?

Access all course materials today

The rest of this tutorial's contents are only available for premium members. Please explore your options at the link below.

Returning members can login to stop seeing this.