1460. Make Two Arrays Equal by Reversing Subarrays
Problem Description
In this problem, you are provided with two integer arrays target
and arr
. Both arrays have the same number of elements. Your goal is to determine if it's possible to make the array arr
identical to the array target
by performing a series of operations. For each operation, you can select any non-empty subarray from arr
and reverse it. A subarray is a contiguous part of an array. You can reverse subarrays as many times as you need. You need to return true
if arr
can be made equal to target
or false
otherwise.
Intuition
The key insight to solve this problem is to understand that reversing a subarray does not change the overall content (numbers and their frequencies) of the array; it only changes the order of elements. If two arrays contain the same elements with the same frequencies (multisets are equal), it is always possible to make one array equal to another by reversing subarrays because you can always rearrange the elements to match. Therefore, the solution does not actually involve performing the subarray reversals; instead, it involves checking whether both arrays contain the same set of elements with the same frequency.
The approach to arrive at the solution is straightforward:
- Sort both the
target
andarr
arrays. Sorting brings elements of the same value next to each other and thus makes it easy to compare the arrays. - After sorting, if both arrays are equal, it means that
arr
can be transformed intotarget
through reversing subarrays. Hence, returntrue
. - If the arrays do not match after sorting, it means
arr
cannot be made equal totarget
, so returnfalse
.
Learn more about Sorting patterns.
Solution Approach
The implementation of the solution is quite simple and uses basic algorithms and data structures. Here is a detailed explanation of the approach:
-
Sorting Algorithm: The core of the solution uses a sorting algorithm. Both Python's
sort()
method on lists uses TimSort, which is a hybrid sorting algorithm derived from merge sort and insertion sort. It is a stable, adaptive, and iterative merge sort that requires fewer than n log(n) comparisons when running on partially sorted arrays, which makes it very efficient. -
Comparison: After sorting, the elements in both
target
andarr
are in the same order if they are comprised of the same set of elements. The algorithm then simply compares the two sorted arrays to check for equality. This is done using the '==' operator in Python, which compares corresponding elements in both lists. -
Returning the Result: If the comparison evaluates to
true
, it means thatarr
can be rearranged to matchtarget
by reversing subarrays; the function thus returnstrue
. If the comparison isfalse
, there are elements inarr
that do not match those intarget
, indicating that no series of reversals will make the two arrays equal. In this case, the function returnsfalse
.
The solution does not require any additional data structures; it works with the input arrays themselves and returns a boolean value. It is also important to note that since sorting changes the original arrays, if maintaining the original order is needed for any reason, one could sort copies of the arrays instead.
Here is the final solution encapsulated in a class, as provided in the reference code:
1class Solution:
2 def canBeEqual(self, target: List[int], arr: List[int]) -> bool:
3 target.sort()
4 arr.sort()
5 return target == arr
The above solution is concise as well as efficient due to the use of sorting, which is more time and space-efficient than other methods of comparison that could involve using hash maps or multiset data structures to compare frequencies of elements.
Ready to land your dream job?
Unlock your dream job with a 2-minute evaluator for a personalized learning plan!
Start EvaluatorExample Walkthrough
Let us consider a small example to illustrate the solution approach.
Suppose the target
array is [1, 2, 3, 4]
and the arr
array is [2, 4, 1, 3]
. We want to find out if we can make arr
identical to target
by reversing subarrays.
Following the solution approach:
-
Sorting the arrays: We start by sorting both
target
andarr
.After sorting,
target
remains[1, 2, 3, 4]
because it was already sorted. Thearr
array after sorting becomes[1, 2, 3, 4]
. -
Comparing the sorted arrays: Now, we compare the sorted
target
array with the sortedarr
array.Since
sorted_target == [1, 2, 3, 4]
andsorted_arr == [1, 2, 3, 4]
, comparison shows that both arrays are identical. -
Result: As the sorted arrays are identical, we can conclude that it is possible to make
arr
identical totarget
by reversing subarrays.
Hence, according to the solution approach outlined in the problem content, the function would return true
for these arrays.
Solution Implementation
1from typing import List # Import List from typing module for type annotations
2
3class Solution:
4 def canBeEqual(self, target: List[int], arr: List[int]) -> bool:
5 """
6 Check if two lists, target and arr, can be made equal through sorting.
7
8 Args:
9 target (List[int]): The target list that arr should match.
10 arr (List[int]): The list to compare with the target list.
11
12 Returns:
13 bool: True if arr can be made equal to target by sorting, False otherwise.
14 """
15 # Sort both the target list and arr list in place
16 target.sort()
17 arr.sort()
18
19 # After sorting, if target is equal to arr, it means arr can be made equal
20 # to target by sorting. Otherwise, it's not possible.
21 return target == arr
22
1class Solution {
2
3 public boolean canBeEqual(int[] target, int[] arr) {
4 // Sort the target array in-place
5 Arrays.sort(target);
6 // Sort the arr array in-place
7 Arrays.sort(arr);
8
9 // Check if the sorted arrays are equal
10 // The equals method checks if the two arrays have the same elements in the same order
11 return Arrays.equals(target, arr);
12 }
13}
14
1#include <vector> // Include vector header for using vectors
2#include <algorithm> // Include algorithm header for using sort function
3
4class Solution {
5public:
6 // Method to determine if two vectors can be made equal by reordering
7 bool canBeEqual(vector<int>& target, vector<int>& arr) {
8 // Sort the target vector in non-decreasing order
9 sort(target.begin(), target.end());
10
11 // Sort the arr vector in non-decreasing order
12 sort(arr.begin(), arr.end());
13
14 // Compare the sorted vectors to check if they are equal
15 return target == arr;
16 }
17};
18
1function canBeEqual(target: number[], arr: number[]): boolean {
2 // Determine the length of the 'target' array.
3 const arrayLength = target.length;
4
5 // Initialize an array for counting occurrences with fixed size 1001, filled with zeros.
6 // This is based on the constraint that the elements in 'target' and 'arr' are integers between 1 and 1000.
7 const occurrenceCount = new Array(1001).fill(0);
8
9 // Iterate over each element of 'target' and 'arr'.
10 for (let index = 0; index < arrayLength; index++) {
11 // Increment the count for the current element in 'target'.
12 occurrenceCount[target[index]]++;
13 // Decrement the count for the current element in 'arr'.
14 occurrenceCount[arr[index]]--;
15 }
16
17 // Check if every value in our counting array is zero.
18 // If so, this means 'target' and 'arr' have the same elements with the same quantity.
19 return occurrenceCount.every(value => value === 0);
20}
21
Time and Space Complexity
Time Complexity
The given code consists of two sort operations and one equality check operation. The sort operations on both target
and arr
are the dominant factors in the time complexity of this function.
Assuming that the sort function is based on an algorithm with O(n log n) time complexity such as Timsort (which is the sorting algorithm used by Python's built-in sort method), the time complexity for sorting both lists would be O(n log n)
, where n
is the length of the lists.
The time complexity would be the sum of sorting the two lists:
- First sort:
O(target.length log(target.length))
- Second sort:
O(arr.length log(arr.length))
Since the question implies that both lists should be of the same length for them to be possibly equal, we can assume target.length
== arr.length
and use n
as the length for both:
- Total time for sorting:
2 * O(n log n)
The equality check operation that follows (target == arr
) compares each element between the two lists, which has a time complexity of O(n)
.
However, since the time for sorting (O(n log n)
) is greater than the time for comparison (O(n)
), the overall time complexity of the function is dominated by the sorting time:
- Overall time complexity:
O(n log n)
Space Complexity
Considering the space complexity, the sort operations are done in-place in Python, which means that no additional space proportional to the input size is required beyond a constant amount used by the sorting algorithm itself.
Thus, the space complexity of the function is:
- Space complexity:
O(1)
(constant space complexity, not counting the input and output)
Learn more about how to find time and space complexity quickly using problem constraints.
Which of the two traversal algorithms (BFS and DFS) can be used to find whether two nodes are connected?
Recommended Readings
Sorting Summary Comparisons We presented quite a few sorting algorithms and it is essential to know the advantages and disadvantages of each one The basic algorithms are easy to visualize and easy to learn for beginner programmers because of their simplicity As such they will suffice if you don't know any advanced
Patterns The Shortest Path Algorithm for Coding Interviews The goal of AlgoMonster is to help you get a job in the shortest amount of time possible in a data driven way We compiled datasets of tech interview problems and broke them down by patterns This way we can determine the
Recursion Recursion is one of the most important concepts in computer science Simply speaking recursion is the process of a function calling itself Using a real life analogy imagine a scenario where you invite your friends to lunch https algomonster s3 us east 2 amazonaws com recursion jpg You first
Got a question?ย Ask the Monster Assistantย anything you don't understand.
Still not clear? ย Submitย the part you don't understand to our editors. Or join ourย Discord and ask the community.