data:image/s3,"s3://crabby-images/e0c20/e0c20528f272b1b5ae8291f4edbbdc8d42a84a42" alt="Data Structures and Algorithms in Java"
Concept explainers
Explanation of Solution
Recursive method to determine the sum of two elements is equal to “n”:
Create the method FindPair() that accepts the input parameter as “a”, “low”, “high”, and “n” to determine the sum of two elements in an array “a” is equal to “n” by calling this method recursively.
Method definition:
//Define the FindPair() method
public static boolean FindPair(int a[], int low, int high, int n)
{
//Check whether the "low" is equal to "high"
if(low == high)
/*Return false, if there are no elements in array "a" that sum is equal to "n". */
return false;
/*Otherwise, check whether the sum of "a[low]" and "a[high]" is less than "n". */
else if((a[low]+a[high]) < n)
/*Call FindPair() method recursively by passing the parameters as "a", "low+1", "high" and "n" to sum the two elements is equal to "n". */
return FindPair(a, low+1, high, n);
/*Otherwise, check whether the sum of "a[low]" and "a[high]" is greater than "n". */
else if((a[low]+a[high]) > n)
/*Call FindPair() method recursively by passing the parameters as "a", "low", "high-1" and "n" to sum the two elements is equal to "n". */
return FindPair(a, low, high-1, n);
else
/*Return true, if there are elements in array "a" that sum is equal to "n". */
return true;
}
Explanation:
In the above code,
- In the FindPair() method,
- It accepts the input parameter as “a”, “low”, “high”, and “n”.
- Check whether the “low” is equal to “high”. If yes,
- Return false, if there are no elements in array “a” that sum is equal to “n”.
- Otherwise, check whether the sum of “a[low]” and “a[high]” is less than “n”. If yes,
- Call FindPair() method recursively by passing the parameters as “a”, “low+1”, “high”, and “n” to sum the two elements is equal to “n”...
data:image/s3,"s3://crabby-images/2698b/2698b129880c27e76a91019c9f73226195062b2d" alt="Check Mark"
Want to see the full answer?
Check out a sample textbook solutiondata:image/s3,"s3://crabby-images/dcc24/dcc24561111272e79a148ae4d6ab4a805bb28b11" alt="Blurred answer"
Chapter 5 Solutions
Data Structures and Algorithms in Java
- C++ Programming: From Problem Analysis to Program...Computer ScienceISBN:9781337102087Author:D. S. MalikPublisher:Cengage LearningProgramming Logic & Design ComprehensiveComputer ScienceISBN:9781337669405Author:FARRELLPublisher:CengageC++ for Engineers and ScientistsComputer ScienceISBN:9781133187844Author:Bronson, Gary J.Publisher:Course Technology Ptr
- Systems ArchitectureComputer ScienceISBN:9781305080195Author:Stephen D. BurdPublisher:Cengage LearningNew Perspectives on HTML5, CSS3, and JavaScriptComputer ScienceISBN:9781305503922Author:Patrick M. CareyPublisher:Cengage LearningProgramming with Microsoft Visual Basic 2017Computer ScienceISBN:9781337102124Author:Diane ZakPublisher:Cengage Learning
data:image/s3,"s3://crabby-images/7459b/7459bf678b74427bda237ab38d4b5d3949952a7e" alt="Text book image"
data:image/s3,"s3://crabby-images/1d7e7/1d7e7583d6f456277727f8d158d820c51233aa30" alt="Text book image"
data:image/s3,"s3://crabby-images/b907a/b907ada1f4be11d175260bd2a8acbc475b9f1fe1" alt="Text book image"
data:image/s3,"s3://crabby-images/98972/989727d766ccf442180c55aad7555e2e9b7e252f" alt="Text book image"
data:image/s3,"s3://crabby-images/afea1/afea10491f15304b6bbfa1832aa7a5981316582f" alt="Text book image"