Given an array arr[] of size N, the task is to find indices of array elements whose removal makes the sum of odd and even indexed elements equal. If no such element exists, then print -1.
Examples:
Input: arr[] = {4, 1, 6, 2}
Output: 1
Explanation:
Removing arr[1] modifies arr[] to {4, 6, 2}
Sum of even-indexed array elements = arr[0] + arr[2] = 4 + 2 = 6
Sum of odd-indexed array elements = arr[1] = 6
Therefore, the required output is 1.
Input:arr = {3, 2, 1}
Output: -1
Naive Approach: The simplest approach to solve this problem to traverse the array and remove the ith element from the array and check if the sum of odd-indexed array elements equal to the sum of even-indexed array elements or not. If found to be true then print the index.
Time Complexity: O(N2)
Auxiliary Space: O(N)
Efficient Approach: The above approach can be optimized using the Prefix Sum technique. The idea is to use the fact that If an array element removed from the index, then after that index, the even-indexed array elements become the odd-indexed and vice-versa. Follow the steps below to solve the problem:
- Initialize two arrays, say odd[] and even[], to store the prefix sum of odd and even-indexed array elements and prefix sum of even-indexed array elements respectively.
- Traverse the array arr[] and compute prefix sum of odd and even-indexed array elements.
- Initialize two variables, say P = 0 and Q = 0, to store the sum of even and odd-indexed array elements respectively after removal of an array element.
- Traverse the array and remove array elements one by one and update prefix sums accordingly. Check if the sum of even-indexed array elements, P, is equal to the sum of odd-indexed array elements, Q or not. If found to be true, then print the current index.
- Otherwise, print -1.
Below is the implementation of the above approach:
C++
#include <bits/stdc++.h>
using namespace std;
void removeIndicesToMakeSumEqual(vector< int >& arr)
{
int N = arr.size();
vector< int > odd(N, 0);
vector< int > even(N, 0);
even[0] = arr[0];
for ( int i = 1; i < N; i++) {
odd[i] = odd[i - 1];
even[i] = even[i - 1];
if (i % 2 == 0) {
even[i] += arr[i];
}
else {
odd[i] += arr[i];
}
}
bool find = 0;
int p = odd[N - 1];
int q = even[N - 1] - arr[0];
if (p == q) {
cout << "0 " ;
find = 1;
}
for ( int i = 1; i < N; i++) {
if (i % 2 == 0) {
p = even[N - 1] - even[i - 1]
- arr[i] + odd[i - 1];
q = odd[N - 1] - odd[i - 1]
+ even[i - 1];
}
else {
q = odd[N - 1] - odd[i - 1]
- arr[i] + even[i - 1];
p = even[N - 1] - even[i - 1]
+ odd[i - 1];
}
if (p == q) {
find = 1;
cout << i << " " ;
}
}
if (!find) {
cout << -1;
}
}
int main()
{
vector< int > arr = { 4, 1, 6, 2 };
removeIndicesToMakeSumEqual(arr);
return 0;
}
|
Java
import java.util.*;
class GFG{
static void removeIndicesToMakeSumEqual( int []arr)
{
int N = arr.length;
int []odd = new int [N];
int []even = new int [N];
even[ 0 ] = arr[ 0 ];
for ( int i = 1 ; i < N; i++)
{
odd[i] = odd[i - 1 ];
even[i] = even[i - 1 ];
if (i % 2 == 0 )
{
even[i] += arr[i];
}
else
{
odd[i] += arr[i];
}
}
boolean find = false ;
int p = odd[N - 1 ];
int q = even[N - 1 ] - arr[ 0 ];
if (p == q)
{
System.out.print( "0 " );
find = true ;
}
for ( int i = 1 ; i < N; i++)
{
if (i % 2 == 0 )
{
p = even[N - 1 ] - even[i - 1 ] -
arr[i] + odd[i - 1 ];
q = odd[N - 1 ] - odd[i - 1 ] +
even[i - 1 ];
}
else
{
q = odd[N - 1 ] - odd[i - 1 ] -
arr[i] + even[i - 1 ];
p = even[N - 1 ] - even[i - 1 ] +
odd[i - 1 ];
}
if (p == q)
{
find = true ;
System.out.print(i + " " );
}
}
if (!find)
{
System.out.print(- 1 );
}
}
public static void main(String[] args)
{
int [] arr = { 4 , 1 , 6 , 2 };
removeIndicesToMakeSumEqual(arr);
}
}
|
Python3
def removeIndicesToMakeSumEqual(arr):
N = len (arr);
odd = [ 0 ] * N;
even = [ 0 ] * N;
even[ 0 ] = arr[ 0 ];
for i in range ( 1 , N):
odd[i] = odd[i - 1 ];
even[i] = even[i - 1 ];
if (i % 2 = = 0 ):
even[i] + = arr[i];
else :
odd[i] + = arr[i];
find = False ;
p = odd[N - 1 ];
q = even[N - 1 ] - arr[ 0 ];
if (p = = q):
print ( "0 " );
find = True ;
for i in range ( 1 , N):
if (i % 2 = = 0 ):
p = even[N - 1 ] - even[i - 1 ] - arr[i] + odd[i - 1 ];
q = odd[N - 1 ] - odd[i - 1 ] + even[i - 1 ];
else :
q = odd[N - 1 ] - odd[i - 1 ] - arr[i] + even[i - 1 ];
p = even[N - 1 ] - even[i - 1 ] + odd[i - 1 ];
if (p = = q):
find = True ;
print (i, end = "");
if (find = = False ):
print ( - 1 );
if __name__ = = '__main__' :
arr = [ 4 , 1 , 6 , 2 ];
removeIndicesToMakeSumEqual(arr);
|
C#
using System;
class GFG{
static void removeIndicesToMakeSumEqual( int []arr)
{
int N = arr.Length;
int []odd = new int [N];
int []even = new int [N];
even[0] = arr[0];
for ( int i = 1; i < N; i++)
{
odd[i] = odd[i - 1];
even[i] = even[i - 1];
if (i % 2 == 0)
{
even[i] += arr[i];
}
else
{
odd[i] += arr[i];
}
}
bool find = false ;
int p = odd[N - 1];
int q = even[N - 1] - arr[0];
if (p == q)
{
Console.Write( "0 " );
find = true ;
}
for ( int i = 1; i < N; i++)
{
if (i % 2 == 0)
{
p = even[N - 1] - even[i - 1] -
arr[i] + odd[i - 1];
q = odd[N - 1] - odd[i - 1] +
even[i - 1];
}
else
{
q = odd[N - 1] - odd[i - 1] -
arr[i] + even[i - 1];
p = even[N - 1] - even[i - 1] +
odd[i - 1];
}
if (p == q)
{
find = true ;
Console.Write(i + " " );
}
}
if (!find)
{
Console.Write(-1);
}
}
public static void Main(String[] args)
{
int [] arr = { 4, 1, 6, 2 };
removeIndicesToMakeSumEqual(arr);
}
}
|
Javascript
<script>
function removeIndicesToMakeSumEqual(arr) {
var N = arr.length;
var odd = Array(N).fill(0);
var even = Array(N).fill(0);
even[0] = arr[0];
for (i = 1; i < N; i++) {
odd[i] = odd[i - 1];
even[i] = even[i - 1];
if (i % 2 == 0) {
even[i] += arr[i];
}
else {
odd[i] += arr[i];
}
}
var find = false ;
var p = odd[N - 1];
var q = even[N - 1] - arr[0];
if (p == q) {
document.write( "0 " );
find = true ;
}
for (i = 1; i < N; i++) {
if (i % 2 == 0) {
p = even[N - 1] - even[i - 1] - arr[i] + odd[i - 1];
q = odd[N - 1] - odd[i - 1] + even[i - 1];
} else {
q = odd[N - 1] - odd[i - 1] - arr[i] + even[i - 1];
p = even[N - 1] - even[i - 1] + odd[i - 1];
}
if (p == q) {
find = true ;
document.write(i + " " );
}
}
if (!find) {
document.write(-1);
}
}
var arr = [ 4, 1, 6, 2 ];
removeIndicesToMakeSumEqual(arr);
</script>
|
Time Complexity: O(N)
Auxiliary Space: O(N)