lab03 : Recursion
| num | ready? | description | assigned | due |
|---|---|---|---|---|
| lab03 | true | Recursion | Sun 04/23 11:59PM | Sun 04/30 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.
Note: In general, it is always important to work on labs and reading early so you can gain the proper context and utilize our office hours to seek assistance / ask clarifying questions during the weekdays before the deadline if needed!
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.pyin 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.pyin 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 of your own 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.
multiply(x, y)- The parametersxandyare positive integers (including 0). This function recursively returns the product ofxandywithout explicitly multiplying the two numbers together.
# Example test
assert multiply(5,4) == 20
collectMultiples(intList, n)- The parameterintListcontains a list of positive integers >= 1, andnis a positive integer >= 1. This function recursively returns a list containing elements inintListthat are multiples ofnin the order that they appear inintList. If there are no multiples ofninintList, then this function should return an empty list.
# Example test
assert collectMultiples([1,3,5,7,9], 3) == [3,9]
countVowels(s)- This function will take a string value (s) and recursively 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
reverseVowels(s)- This function will take a string value (s) and recursively return a string containing only the vowels (‘A’,’E’,’I’,’O’,’U’,’a’,’e’,’i’,’o’,’u’) insin reverse order.
# Example test
assert reverseVowels("Eunoia") == "aiouE"
removeSubString(s, sub)- The parameterssandsubare strings that contain at least one character. This function will recursively return a string where all occurrences ofsubare removed in the order it appears in the strings(see example test below for an interesting case). Your solution SHOULD NOT use the string’sreplacemethod.
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 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.