-
-
Notifications
You must be signed in to change notification settings - Fork 24
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Create 07(Nov) Split array in three equal sum subarrays.md
- Loading branch information
Showing
1 changed file
with
172 additions
and
0 deletions.
There are no files selected for viewing
172 changes: 172 additions & 0 deletions
172
November 2024 GFG SOLUTION/07(Nov) Split array in three equal sum subarrays.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,172 @@ | ||
# *07. Split Array in Three Equal Sum Subarrays* | ||
|
||
The problem can be found at the following link: [Problem Link](https://www.geeksforgeeks.org/problems/split-array-in-three-equal-sum-subarrays/1) | ||
|
||
## Problem Description | ||
|
||
Given an array `arr[]`, determine if the array can be split into three consecutive parts such that the sum of each part is equal. If it’s possible, return any index pair `(i, j)` in the array such that the sum of the subarray `arr[0..i]` is equal to the sum of the subarray `arr[i+1..j]` and equal to the sum of the subarray `arr[j+1..n-1]`. Otherwise, return `{-1, -1}`. | ||
|
||
Note: The driver code will print `true` if the array can be split into three equal sum subarrays; otherwise, it will print `false`. | ||
|
||
### Examples: | ||
|
||
**Input:** | ||
``` | ||
arr[] = [1, 3, 4, 0, 4] | ||
``` | ||
|
||
**Output:** | ||
``` | ||
true | ||
``` | ||
|
||
**Explanation:** | ||
The pair `(1, 2)` is valid because the sum of subarrays `arr[0..1]`, `arr[2..3]`, and `arr[4..4]` are all equal to 4. | ||
|
||
**Input:** | ||
``` | ||
arr[] = [2, 3, 4] | ||
``` | ||
|
||
**Output:** | ||
``` | ||
false | ||
``` | ||
|
||
**Explanation:** | ||
No three subarrays exist which have equal sums. | ||
|
||
**Input:** | ||
``` | ||
arr[] = [0, 1, 1] | ||
``` | ||
|
||
**Output:** | ||
``` | ||
false | ||
``` | ||
|
||
## My Approach | ||
|
||
1. **Sum Calculation and Check:** | ||
- First, compute the total sum of the array. | ||
- If the total sum is not divisible by 3, return `{-1, -1}` because it’s impossible to split the array into three parts with equal sums. | ||
|
||
2. **Iterative Approach to Find the Split:** | ||
- Traverse the array while maintaining the running sum of the elements. | ||
- Keep track of how many times we encounter a sum that equals `totalSum / 3` (the first partition), and then check for when the second partition reaches `2 * totalSum / 3`. | ||
- Once both conditions are met, return the indices that define the partitions. | ||
|
||
## Time and Auxiliary Space Complexity | ||
|
||
- **Expected Time Complexity:** O(n), where `n` is the number of elements in the array. We perform a linear scan to compute the sum and then another scan to check the partition conditions. | ||
- **Expected Auxiliary Space Complexity:** O(1), as we use a constant amount of additional space to track the running sum and indices. | ||
|
||
## Code (C++) | ||
|
||
```cpp | ||
class Solution { | ||
public: | ||
vector<int> findSplit(vector<int>& arr) { | ||
int n = arr.size(); | ||
int totalSum = accumulate(arr.begin(), arr.end(), 0); | ||
|
||
if (totalSum % 3 != 0) | ||
return {-1, -1}; | ||
|
||
int target = totalSum / 3; | ||
int currentSum = 0; | ||
int countFirst = 0; | ||
|
||
for (int i = 0; i < n; ++i) { | ||
currentSum += arr[i]; | ||
|
||
if (currentSum == 2 * target && countFirst > 0) | ||
return {countFirst - 1, i}; | ||
|
||
if (currentSum == target) { | ||
countFirst++; | ||
} | ||
} | ||
|
||
return {-1, -1}; | ||
} | ||
}; | ||
``` | ||
|
||
## Code (Java) | ||
|
||
```java | ||
class Solution { | ||
public List<Integer> findSplit(int[] arr) { | ||
int n = arr.length; | ||
int totalSum = 0; | ||
for (int i = 0; i < n; i++) { | ||
totalSum += arr[i]; | ||
} | ||
|
||
if (totalSum % 3 != 0) | ||
return Arrays.asList(-1, -1); | ||
|
||
int target = totalSum / 3; | ||
int currentSum = 0; | ||
int countFirst = 0; | ||
|
||
for (int i = 0; i < n; i++) { | ||
currentSum += arr[i]; | ||
|
||
if (currentSum == 2 * target && countFirst > 0) | ||
return Arrays.asList(countFirst - 1, i); | ||
|
||
if (currentSum == target) { | ||
countFirst++; | ||
} | ||
} | ||
|
||
return Arrays.asList(-1, -1); | ||
} | ||
} | ||
``` | ||
|
||
## Code (Python) | ||
|
||
```python | ||
class Solution: | ||
def findSplit(self, arr): | ||
n = len(arr) | ||
totalSum = sum(arr) | ||
|
||
if totalSum % 3 != 0: | ||
return [-1, -1] | ||
|
||
target = totalSum // 3 | ||
currentSum = 0 | ||
countFirst = 0 | ||
|
||
for i in range(n): | ||
currentSum += arr[i] | ||
|
||
if currentSum == 2 * target and countFirst > 0: | ||
return [countFirst - 1, i] | ||
|
||
if currentSum == target: | ||
countFirst += 1 | ||
|
||
return [-1, -1] | ||
``` | ||
|
||
## Contribution and Support | ||
|
||
For discussions, questions, or doubts related to this solution, feel free to connect on LinkedIn: [Any Questions](https://www.linkedin.com/in/het-patel-8b110525a/). Let’s make this learning journey more collaborative! | ||
|
||
⭐ If you find this helpful, please give this repository a star! ⭐ | ||
|
||
--- | ||
|
||
<div align="center"> | ||
<h3><b>📍Visitor Count</b></h3> | ||
</div> | ||
|
||
<p align="center"> | ||
<img src="https://profile-counter.glitch.me/Hunterdii/count.svg" /> | ||
</p> |