You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I looked through the open and closed issue titles several times and did a search but didn't see anything related. I also reviewed my code several times to see if I made a mistake somewhere but I don't see one so I think this is an issue.
Chapter: 5
Page Number: 238 of pdf
Section Title: Implementing functionality using methods
Step Number: 2, 4, 5
Problem to fix:
In step 4 we set up Lamech to get married twice:
However, the instance method "Marry" defined in step 2 checks to see if the person is already married which breaks out of the recursion but also prevents subsequent marriages from occurring - "if (married) return":
So in step 4 when we try to marry zillah and lamech, it doesn't work. Then later in step 4 we call the "Procreate" method between the 2 but they aren't spouses so it triggers the exception:
Output from vscode terminal:
vs.
Output in book:
Suggested solution:
Seems there could be various ways to "fix" this or restructure but here is what I came up with:
Have the spouse field be a List<Person>
Remove the married check in "Marry" method. Instead, check if partner name is in Spouse list and return to break out of the recursion.
In "Procreate" method, check that the spouse is in the list before continuing.
Created a "DisplaySpouses" static method that takes in a person and checks their Spouse list to write the names to the console
The text was updated successfully, but these errors were encountered:
I was actually expecting this error but then the code seemed to run fine. Because of the order in which the instances are used in the example, Lamech becomes Zillah's spouse, although Adah remains Lamesh's spouse. Then the Procreate function also ends up working in the example because p1 is Lamesh for the first baby and Zillah for the second.
I guess this is a good example of how code can seem to work before proper testing, but run into issues when different cases are used.
Still, glad that somebody raised the issue, I was beginning to think I had misunderstood the code.
I looked through the open and closed issue titles several times and did a search but didn't see anything related. I also reviewed my code several times to see if I made a mistake somewhere but I don't see one so I think this is an issue.
Chapter: 5
Page Number: 238 of pdf
Section Title: Implementing functionality using methods
Step Number: 2, 4, 5
Problem to fix:
In step 4 we set up Lamech to get married twice:
However, the instance method "Marry" defined in step 2 checks to see if the person is already married which breaks out of the recursion but also prevents subsequent marriages from occurring - "if (married) return":
So in step 4 when we try to marry zillah and lamech, it doesn't work. Then later in step 4 we call the "Procreate" method between the 2 but they aren't spouses so it triggers the exception:
Output from vscode terminal:
vs.
Output in book:
Suggested solution:
Seems there could be various ways to "fix" this or restructure but here is what I came up with:
Have the spouse field be a List<Person>
Remove the married check in "Marry" method. Instead, check if partner name is in Spouse list and return to break out of the recursion.
In "Procreate" method, check that the spouse is in the list before continuing.
Created a "DisplaySpouses" static method that takes in a person and checks their Spouse list to write the names to the console
The text was updated successfully, but these errors were encountered: