GSA 04 - Ciphers
Goals for this assignment
By the time you have completed this assignment, you should be able to
- Process command line arguments
- Work with C-strings
- Iterating arrays
- Read input from
cin
Step by Step Instructions
Step 1: Getting Ready
-
Go to github and find a repo for this assignment assigned to your GitHub id.
-
Log on to your CSIL account.
-
Change into your
~/cs16
directory -
Clone your empty gsa04 repo into your
~/cs16
directory. -
In your empty repo, do
git checkout -b main
to establish that you are on themain
branch as your default branch.
Step 2: Obtain the starter code
The starter code is in this repo:
The URL for cloning this repo is this: git@github.com:ucsb-cs16-s24/STARTER-gsa04.git
Previous assignments contain instruction for the process of:
- Adding a
starter
remote for this repo - Pulling the code from that
starter
remote into your own repo.
Please do those steps now, and then do a git push origin main
to populate your own repo with the starter code.
If you need help with these steps:
- First consult previous assignments for more detailed instructions.
- Then, if you are still having trouble, ask the staff for help during discussion section or office hours.
Once you’ve populated your repo, typing the ls
command should show you the following files in your current directory
[user@csilvm-xx gsa04]$ ls
Makefile caesar.cpp substitution.cpp
Step 3: Caesar
In caesar.cpp
, finish the program that implements a Caesar cipher.
Your program should expect two command line arguments. The first argument must be either -e
(for encryption) or -d
(for decryption). The second argument must be a non-negative integer. If the user provides the wrong number of command line arguments, if the first argument is not expected, or if the second argument is not composed entirely of the digits 0
through 9
, print a usage message and exit with exit code 1 to indicate that there was an error:
[user@csilvm-xx gsa04]$ ./caesar
USAGE: caesar [-ed] [key]
If the user provides valid command line arguments, your program should read its standard input one line at a time. It should then either encrypt or decrypt the line and print the result. When encrypting, all English letters (a
through z
and A
through Z
) should be “rotated right” by the user-supplied key (an a
rotated right 3 would become a d
, and a y
rotated right by 3 would become a b
). Capitalization should be preserved, and all non-letter characters should be left unchanged.
[user@csilvm-xx gsa04]$ ./caesar -e 3
abcdefghijklmnopqrstuvwxyz
defghijklmnopqrstuvwxyzabc
Veni, vidi, vici.
Yhql, ylgl, ylfl.
When decrypting, all letters should be rotated left.
[user@csilvm-xx gsa04]$ ./caesar -d 5
Frtw Anshny Trsnf
Amor Vincit Omnia
The key may be greater than twenty-six. Note that when the key is a multiple of 26, the input should be unchanged.
Step 4: Substitution
In this substitution.cpp
, finish the program that uses a substitution cipher to encrypt or decrypt its input.
Your program should take two command line arguments: the first argument must be either -e
(for encryption) or -d
(for decryption). The second argument must be a twenty-six-character string containing each letter of the alphabet exactly once. If you run the program with the wrong number of arguments, or if any argument is invalid, it should print a usage message and exit with exit code 1:
[user@csilvm-xx gsa04]$ ./substitution
USAGE: substitution [-ed] [key]
If the command line arguments are valid, your program should read its input one line at a time, encrypting or decrypting each line and then printing the result. When encrypting, the letter A
should be replaced with the first letter of the key, the letter B
with the second, C
with the third, and so on.
[user@csilvm-xx gsa04]$ ./substitution -e egjhvakrzxpsynbtudmqiclfow
Outside of a dog, a book is man's best friend.
Biqmzhv ba e hbk, e gbbp zm yen'm gvmq adzvnh.
Inside of a dog, it's too dark to read.
Znmzhv ba e hbk, zq'm qbb hedp qb dveh.
To make it easier to see what happened in the example above, you can line up the key with the unmodified alphabet. Each letter in the alphabet maps to the letter in the key at the same index:
abcdefghijklmnopqrstuvwxyz
egjhvakrzxpsynbtudmqiclfow
When decrypting, the first letter of the key should be replaced with A
, the second letter with B
, the third with C
, and so on.
[user@csilvm-xx gsa04]$ ./substitution -d rptxnfhewgzdkicmbujsavloqy
Leq jecadx ln ervn r jsrixwih rukq?
Why should we have a standing army?
Pntrajn sers lrq ln jrvn kcinq ci terwuj.
Because that way we save money on chairs.
The letters of the key can be either upper or lower case (or mixed), as long as every letter of the alphabet is present. When encrypting and decrypting, match the case of the input. The key abcdefghijklmnopqrstuvwxyz
will leave the input unchanged.
Tips
To manually send an “end of input” signal while testing, use Ctrl
+D
on Linux and Mac (Ubuntu in WSL counts as Linux), and use Ctrl
+Z
followed by Enter
on Windows.
Step 5: Upload your code to github one last time
Hopefully you remembered to sync your local changes to github often as you were completing the assignment.
If you forgot to do so, be sure to follow the steps in section 1d (above) to upload your final code to github
Step 6: Submit your code to gradescope
Go to our class site on www.gradescope.com. Navigate to the assignment for this assignment and submit your code via github.
You should see a score of 100/100 for this assignment.
Acknowledgement
Assignment originally designed by Kevin Burk