Welcome to collectivesolver - Programming & Software Q&A with code examples. A website with trusted programming answers. All programs are tested and work.

Contact: aviboots(AT)netvision.net.il

Buy a domain name - Register cheap domain names from $0.99 - Namecheap

Scalable Hosting That Grows With You

Secure & Reliable Web Hosting, Free Domain, Free SSL, 1-Click WordPress Install, Expert 24/7 Support

Semrush - keyword research tool

Boost your online presence with premium web hosting and servers

Disclosure: My content contains affiliate links.

39,848 questions

51,769 answers

573 users

How to find the equilibrium index of an array (sum arr[0 to index - 1] == sum arr[index + 1 to size]) in C++

1 Answer

0 votes
#include <iostream>

int getEquilibriumIndex(int arr[], int size) {
    int sum_arr = 0;
    int left_part_sum = 0; 

    for (int i = 0; i < size; i++)
        sum_arr += arr[i];

    for (int i = 0; i < size; i++) {
        sum_arr -= arr[i];

        if (left_part_sum == sum_arr)
            return i;

        left_part_sum += arr[i];
    }

    return -1;
}

int main()
{
    int arr[] = { -9, 2, 5, 8, -7, 4, 1 };

    int size = sizeof(arr) / sizeof(arr[0]);

    std::cout << "equilibrium index = " << getEquilibriumIndex(arr, size);
}




/*
run:

equilibrium index = 3

*/

 



answered Apr 25, 2023 by avibootz
...