Problem Description
You are given a 0-indexed 1-dimensional (1D) integer array original
, and two integers, m
and n
. You are tasked with creating a 2-dimensional (2D) array with m
rows and n
columns using all the elements from original
. The elements from indices 0
to n - 1
(inclusive) of original
should form the first row of the constructed 2D array, the elements from indices n
to 2 * n - 1
(inclusive) should form the second row of the constructed 2D array, and so on. Return an m x n
2D array constructed according to the above procedure, or an empty 2D array if it is impossible.
Key Insights
- To form a valid 2D array, the total number of elements in
original
must equalm * n
. - If the length of
original
is not equal tom * n
, it is impossible to fill the array, and we should return an empty array. - The 2D array can be constructed by iterating through
original
and filling each row based on the calculated indices.
Space and Time Complexity
Time Complexity: O(m * n)
Space Complexity: O(m * n)
Solution
To solve this problem, we will:
- Check if the length of the
original
array is equal tom * n
. If not, return an empty array. - Initialize a 2D array with
m
rows. - Use a loop to fill each row by slicing the
original
array into segments of sizen
. - Return the constructed 2D array.
The key data structure used here is a 2D array (list of lists) to hold the final result.