Academic Integrity: tutoring, explanations, and feedback — we don’t complete graded work or submit on a student’s behalf.

Write a recursive method that has one integer parameter (n) and returns the numb

ID: 3630633 • Letter: W

Question

Write a recursive method that has one integer parameter (n) and returns the number of binary strings of length n that do not have two consecutive 1's. You should not use any loops in your solution. For example, for n = 4, the number of binary strings of length 4 that do not contain two consecutive 1's is 8:
0000,0001,0010,0100,0101,1000,1001,1010
For this problem, your method needs to return only the number of such strings, not the strings themselves.
HINT: The number of such strings is the number of strings that start with a 0 plus the number of strings that start with 10.

Explanation / Answer

public int numStrings(int n)
{
// break cases
if(n == 0) // 1 string of length 0
return 1;
if(n == 1) // 2 strings: 1 and 0
return 2;

// The number of such strings is the number of strings that start with a 0 plus the number of strings that start with 10.
return numStrings(n-1) + numStrings(n-2);
}

Hire Me For All Your Tutoring Needs
Integrity-first tutoring: clear explanations, guidance, and feedback.
Drop an Email at
drjack9650@gmail.com
Chat Now And Get Quote