I was solving practice questions from a book when I stumbled upon this one :
*Describe a recursive algorithm that will check if an array A of
integers contains an integer A[i] that is the sum of two integers
that appear earlier in A, that is, such that
A[i] = A[j] +A[k] for j,k < i.
*
I have been thinking about this for a few hours but haven’t been able to come up with a good recursive algorithm.
A recursive solution without any loops (pseudocode):
The recursive function is called with
check(A, 2, 1, 0). To highlight the main part of the algorithm it does not check if the array initially has more than two elements.