lab03 : Recursion
num | ready? | description | assigned | due |
---|---|---|---|---|
lab03 | true | Recursion | Sun 10/20 11:59PM | Sun 10/27 11:59PM |
In this lab, we’ll practice:
- Writing recursive functions based on a specification.
- Practice writing pytests to ensure your recursive functions are correct.
Instructions
For this lab, you will need to create two files:
lab03.py
- file containing your solution to all recursive functions you will implement in this lab.testFile.py
- file containing pytest functions testing all recursive functions you will implement in this lab. Note: Gradescope’s autograder requires you to submit yourtestFile.py
in order for it to run your code (hopefully you’re practicing TDD and use your tests to check correctness!). Gradescope will also require you to provide all function definitions (even if incorrect) inlab03.py
in order to run the tests.
There will be no starter code for this assignment, but rather function descriptions are given in the specification below.
It’s recommended that you organize your lab work in its own directory. This way all files for a lab are located in a single folder. Also, this will be easy to import various files into your code using the import / from
technique shown in lecture.
Recursive function definitions and specifications
You will write five recursive functions for this lab. Each one is specified below. One example test will be given, but you should write 3 - 5 explicit tests for each function (think of various interesting cases when writing your tests!).
Note: You must write each function recursively in order to receive any credit, even if Gradescope’s tests pass. For this lab, you may not (and need not) define additional helper functions.
integerDivision(n, k)
- The parametersn
andk
are positive integers (you may assumen
is >= 0 andk
is > 0). This function recursively returns the quotient (n // k
) without explicitly using the//
or/
operators, or a pre-defined function.
# Example test
assert integerDivision(27,4) == 6
collectEvenInts(listOfInt)
- The parameterlistOfInt
is a list containing positive integer values. This function will return a list containing only even values inlistOfInt
in the order that they appear inlistOfInt
. If there are no even values inlistOfInt
, then this function should return an empty list.
# Example test
assert collectEvenInts([1,2,3,4,5]) == [2,4]
countVowels(someString)
- This function will take a string value (someString) and return the number of vowels (‘A’,’E’,’I’,’O’,’U’,’a’,’e’,’i’,’o’,’u’) that exists in someString.
# Example test
assert countVowels("This Is A String") == 4
reverseString(s)
- The parameters
is a string. This function will return a string in the reverse order ofs
. Note that the reverse of an empty string is an empty string.
# Example test
assert reverseString("CMPSC9") == "9CSPMC"
removeSubString(s, sub)
- The parameterss
andsub
are strings that contain at least one character. This function will return a string where all occurrences ofsub
are removed in the order it appears in the strings
(see example test below for an interesting case). Your solution SHOULD NOT use the string’sreplace
method.
Example test
assert removeSubString("Lolololol", "lol") == "Loo"
# The first "lol" is removed, which reduces the string
# to: "Loolol". Then the 2nd "lol" is removed, which
# reduces the string to: "Loo"
testFile.py
pytest
This file will contain unit tests using pytest to test if your functionality is correct. Write your own tests first in order to check the correctness of your recursive function. Again, Gradescope requires testFile.py
to be submitted before running any autograded tests. You should write 3 - 5 tests per function.
Submission
Once you’re done with writing your recursive function definitions and tests, submit your lab03.py
and testFile.py
files to the Lab03
assignment on Gradescope. There will be various unit tests Gradescope will run to ensure your code is working correctly based on the specifications given in this lab.
If the tests don’t pass, you may get some error message that may or may not be obvious at this point. Don’t worry - if the tests didn’t pass, take a minute to think about what may have caused the error. If your tests didn’t pass and you’re still not sure why you’re getting the error, feel free to ask your TAs or Learning Assistants.