Multiple recursion helpful info - Tower of Hanoi
Hi everyone,
after some time searching online for answers on how multiple recursion functions are called, here's what helped me:
First I used the function explained in the youtube video from the same teacher linked in this discussion https://365datascience.com/q/3a349f6924 (the one in the course works as well, I just worked on this because it seemed more linear):
data:image/s3,"s3://crabby-images/3b618/3b618e5b1a0b6a4bdcd5d293689b351008f0cd47" alt=""
Then understanding the decision tree -> since our function calls itself twice inside it, each time it's called the tree splits in 2:
data:image/s3,"s3://crabby-images/b0e78/b0e78cfe20618d86d14f8ad65ddde402c729ae19" alt=""
Then we need to clear out what is happening to the variables locally during the calls, since they move around quite a lot:
data:image/s3,"s3://crabby-images/56d0f/56d0fbb9befd73238d22bef8fe977ae84720eaa9" alt=""
data:image/s3,"s3://crabby-images/30cee/30cee3f73e89edcea7a206abe760e638a4a015d2" alt=""
Hope that helps, happy coding!
2 answers ( 0 marked as helpful)
Hey Jessica,
This looks great! Amazing work! Thanks so much for sharing with the other people taking the course.
Visualizing recursive calls as a decision tree is an excellent method to comprehend the branching nature of recursion, especially in multiple recursion scenarios. Each node in the tree represents a function call, and each branch represents a new recursive call initiated by the current function call. This visualization helps in understanding how the recursive calls expand exponentially.
Best,
Ned
I did not understand why the order of the lists inside the function mattered, but your solution helped me visualise it and now I understand that. Thank you for that. But, one thing I still don't understand is how the order of the list changes its meaning, i.e. how does list B go from auxiliary to target just by changing it's order and how does list A go from being target auxiliary etc etc? In the video's solution, we only ever call list A and list C in our base case and in the solution here, we only ever call the target list. I don't really understand how changing the order in which we call the lists inside the function change the position of the list?