Issue
I'm trying to write a method that would Return true if it is possible to divide all the members of an array into two different groups of equal size so that the sum of the members of the two groups is equal. If this is not possible, the method Return false.
The conditions are:
- The method should be recursive with no use of loops at all, So are all the auxiliary methods
Can not contain loops.
- The array is neither null nor empty.
- Do not modify the contents of the array (not even temporarily), and do not use an auxiliary array.
public static boolean equalSplit (int[] arr){
if(arr.length % 2 != 0) // if array length is not equal both sides
return false;
return equalSplit (arr, arr[0],(0 + arr.length-1) / 2 , arr.length-1);
}
public static boolean equalSplit (int[] arr, int start, int mid, int end){
}
I got stuck here and i have no clue what to do next.
Solution
something like this should solve your problem and handle all cases.
public static boolean canBeDividedEqually(int[] arr) {
if (arr.length % 2 != 0) {
return false;
}
int sum = getSum(arr);
if (sum % 2 != 0) {
return false;
}
return canBeDividedEqually(arr, sum);
}
public static int getSum(int[] arr) {
return getSum(arr, 0, 0);
}
private static int getSum(int[] arr, int sum, int index) {
if (index >= arr.length) {
return sum;
}
return getSum(arr, sum + arr[index], index + 1);
}
private static boolean canBeDividedEqually(int[] arr, int sum) {
// this can be optimized by canBeDividedEqually(arr, sum/2, arr[0], arr.length/2, 1, 1) because first element should always belong to first group, so we can start search from second element
return canBeDividedEqually(arr, sum/2, 0, arr.length/2, 0, 0);
// return canBeDividedEqually(arr, sum/2, arr[0], arr.length/2, 1, 1);
}
private static boolean canBeDividedEqually (int[] arr, int searchSum, int currentSum, int searchQuantity, int currentQuantity, int nextIndex) {
if(searchSum == currentSum && searchQuantity == currentQuantity) {
return true;
}
if(searchSum <= currentSum || searchQuantity <= currentQuantity) {
// we have too big sum or we take to much elements
return false;
}
if(nextIndex + (searchQuantity - currentQuantity) > arr.length) {
// we need to take more elements than we have still available
return false;
}
// add current element into account and search further
if(canBeDividedEqually(arr, searchSum, currentSum + arr[nextIndex], searchQuantity, currentQuantity + 1, nextIndex + 1)) {
System.out.println("true");
return true;
}
// if above "if" statement is not true, then skip current element and try to search further
return canBeDividedEqually(arr, searchSum, currentSum, searchQuantity, currentQuantity, nextIndex + 1);
}
Answered By - Grzegorz
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.