lab08 : Anagrams, palindromes: Strings and recursion
num | ready? | description | assigned | due |
---|---|---|---|---|
lab08 | true | Anagrams, palindromes: Strings and recursion | Tue 03/13 09:00AM | Mon 03/19 11:59PM |
Goals of this lab
This lab will have you do programming exercises with C strings, string class objects, recursive functions, and Makefiles. You will also get more practice writing programs from scratch with little skeleton code.
Step 0: Complete the TA/Mentor evaluations
As you may know, we ran a pilot mentor program this quarter. We would like to get your feedback about the program to help us keep the aspects that worked well and identify areas for improvement.
Completing the survey carries course credit (1% of your overall grade), so please be sure to complete it. This is an anonymous survey. To get credit please show the final screen to the instructor TA/tutor
Here is the link to the survey: Please click on this link to complete
You may use the following webpage to identify the mentors should you need it to answer the final question on the survey: https://ucsb-cs16-w18.github.io/info/staff/
To get credit show the final screen of the completed survey to your mentor.
Step 1: Getting Started
-
Decide if you are working alone, or working in a pair. Pair programming is OPTIONAL for this lab.
-
If you are working as a pair, go to submit.cs, navigate to this lab page and create a team for you and your pair partner. Choose who will be the first driver and who will start as navigator, and then remember to switch (at least once) during the lab.
-
Go to github and create a git repo for this lab following the naming convention specified in previous labs (this step carries style points, see our feedback on previous labs to understand what we are looking for). If you are working with a partner only one of you needs to create the repo.
-
If you are working with a partner and you are the one who created the github repo, add your partner as a collaborator on the repo
-
Driver, log on to your CSIL account.
-
Open a terminal window and log into the correct machine.
-
Change into your CS 16 directory
-
Clone your github repo in the ~/cs16/ directory. Then cd into your repo directory.
Note: Remember to push your work to github at the end of EVERY work session. That way, both partners always have access to the latest version of the code even if the code is being developed on one partner’s CoE account.
Step 2: Getting the starter code and writing the programs
This step is similar to lab02, first open terminal and go to the directory where you cloned the starter code in lab02 and pull the latest version of the starter code.
cd ~/cs16/cs16-w18-starter-code
git pull
Clone your github repo in the ~/cs16/ directory. Then cd into your repo directory.
cd ../lab08_gaucho_ally
Copy the code from your starter code directory to your local lab08 repo using the following command.
cp ~/cs16/cs16-w18-starter-code/lab08/* ./
This lab will have you write four functions that are specified in strFuncs.h. You must implement these functions in strFuncs.cpp. You must follow the instructions carefully. It is not enough to pass the submit.cs check as the instructor and the TAs will be checking your submitted program files for style.
Program to find if two strings are anagrams
In the file strFuncs.cpp, write a function called isAnagram that takes two strings as arguments and returns a boolean true if the two strings are anagrams, otherwise it returns false. The function should not be case sensitive and should disregard any punctuation or spaces. Two strings are anagrams if the letters can be rearranged to form each other. For example, “Eleven plus two” is an anagram of “Twelve plus one”. Each string contains one “v”, three “e’s”, two “l’s”, etc. Similarly “Rats and Mice” and “in cat’s dream” are anagrams of each other. You may use any of the C string library or string class functions to complete this code. You may not use built-in C++ functions that we have NOT discussed in lecture. You must follow a TDD style of coding. Write your own test code in a separate file and write a Makefile to compile the code.
Programs to check if an input string is a palindrome
In strFuncs.cpp you are asked to write three different functions - all of which check if a string is a palindrome. For example: “redivide” is not a palindrome, while “detartrated” is a palindrome. You are given different constraints on the implementation of the different functions. Read the instructions in that file carefully to understand the constraints specified for each function. For all the functions you must ignore case when comparing characters of the string.
bool isPalindrome(const string s1);
The above function takes a C++ string as input and returns true if an input string is a palindrome and false if it is not. You can do this by checking if the first character equals the last character, and so on. You may choose a recursive implementation in this case, although it is not required. If you chose a recursive implementation you may or may not choose to write a helper function. You won’t need a helper function is you used the substr (substring) function appropriately in your recursive calls.
bool isPalindrome(const char *s1);
In the next version you are given a function that takes a constant C string as input. In this function you MUST use a recursive implementation and you may not use built-in C++ functions that we have NOT discussed in lecture. It is highly recommended that you implement a helper function with the right set of parameters for implementing the recursive part.
In the last version of the problem you are also for a completely iterative implementation. See the function signature below:
bool isPalindromeIterative(const char *s1);
You must write test code for each of these functions in its own separate file. Once again follow the TDD style of developing your code. Automate you compilation process by writing a Makefile.
Step 3: Submit
Push all your code to github. Then submit your code on submit.cs Here is the command to submit this week’s labs:
~submit/submit -p 928 strFuncs.cpp strFuncs.h tddFuncs.cpp tddFuncs.h
Step 4: Check your submission results
After the 1 minute delay, the submit system will show your score and give you feedback on your submission. Refresh the webpage after a minute to see this information.
You may submit this lab multiple times. You should submit only after local compilation does not produce any errors and runs as expected. The score of the last submission uploaded before the deadline will be used as your assignment grade.
Points assigned by TAs manually (50 pts) Style and test code: You MUST follow the TDD style of test development and test your code extensively. Points will also be given for good choice of variable names, code indented in ways that are consistent, and in line with good C++ practice. Where applicable, common code is factored out into functions.
Step 5: Done!
Remember that we will check your code for appropriate comments, formatting, and the use of required code, as stated earlier.
If you are in the Phelps lab or in CSIL, make sure to log out of the machine before you leave. Also, make sure to close all open programs before you log out. Some programs will not work next time if they are not closed. Remember to save all your open files before you close your text editor.
If you are logged in remotely, you can log out using the exit command:
$ exit