| | | Designing a recursive object |
Designing a recursive object
We talked in class about how to think about recursion:
- Define a type with all of the methods that both base
case and recursive case classes must implement.
- Define an object or class representing the base case(s). Make
sure that all methods from the type are implemented. Convince
yourself that the methods work correctly. (Usually they just do
very trivial things!)
- Define the recursive class(es). Defs and
instance variables that have the same type of object as being constructed
should only refer to objects simpler than the one being
constructed. In particular, the construction of simpler objects in
the body of the class should eventually end up at a base case.
Convince yourself that the initialization will be correct under the
assumption that the construction of simpler objects is correct.
- Write each method under the assumption that it works
correctly on all simpler objects. Convince yourself that the
methods will be correct under the assumption that instance
variables hold simpler objects.
| | | Designing a recursive object |