How to find all combinations of three elements in an array whose sum is equal to N in C++

1 Answer

0 votes
#include <iostream>
 
void PrintThreeElements(int arr[], int size, int N) {
    for (int i = 0; i < size; i++) {
        for (int j = i + 1; j < size; j++) {
            for (int k = j + 1 ; k < size; k++) {
                if (arr[i] + arr[j] + arr[k] == N) {
                   std::cout << arr[i] << " " << arr[j] << " " << arr[k] << "\n";
                   break;
                }
            }
        }
    }
}
 
int main()
{
    int arr[] = {3, 2, 6, 4, 10, 5, 9, 7, 8, 12};
    int N = 24;
    int size = sizeof(arr)/sizeof(arr[0]); 
 
    PrintThreeElements(arr, size, N);
}
 
 
 
 
/*
run:
 
3 9 12
2 10 12
6 10 8
4 8 12
10 5 9
5 7 12
9 7 8
 
*/

 

 



answered Sep 7, 2022 by avibootz
...