The goal of this lab is to implement the Stack Abstract Data Type using two different implementations:
- The built in List construct in Python
- The simple linked data structure covered in class
As part of the Stack definition for this lab, we will specify a capacity for the stack. In the case of the Python List implementation, you will allocate a list of size capacity and use this to store the items in the stack. Since Lists in Python expand when more storage is needed, you must avoid using any functions that would cause a List to expand (see the list (haha) of forbidden methods/operations below). This prevents the stack from growing if the user accesses the List through the given interface. (This prevents the stack from using more space than a user might want. Think of this as a requirement for an application on a small device that has very limited storage.) For consistency, in the simple linked data structure implementation, we will also have a capacity attribute for the stack.
You are NOT allowed to use the following Python List operations:
- append()
- insert()
- extend()
- remove()
- pop()
- + (concatenations)
The following starter files are available on GitHub:
- py: Contains an array (Python List) based implementation of the Stack class
- py: Contains a linked based implementation of the Stack class
- py: Contains your set of thorough tests to ensure your implementations work correctly.
(Note that the class in each stack implementation is named Stack, and both implementations must follow the same specification. This allows one set of tests in stack_tests.py that can be used for both implementations by just changing which file is used when importing Stack.
Reviews
There are no reviews yet.