Substitution
Problem to Solve
In a substitution cipher, we “encrypt” (i.e., conceal in a reversible way) a message by replacing every letter with another letter. To do so, we use a key: in this case, a mapping of each of the letters of the alphabet to the letter it should correspond to when we encrypt it. To “decrypt” the message, the receiver of the message would need to know the key, so that they can reverse the process: translating the encrypt text (generally called ciphertext) back into the original message (generally called plaintext).
A key, for example, might be the string NQXPOMAFTRHLZGECYJIUWSKDVB. This 26-character key means that A (the first letter of the alphabet) should be converted into N (the first character of the key), B (the second letter of the alphabet) should be converted into Q (the second character of the key), and so forth.
A message like HELLO, then, would be encrypted as FOLLE, replacing each of the letters according to the mapping determined by the key.
In a file called substitution.c in a folder called substitution, create a program that enables you to encrypt messages using a substitution cipher. At the time the user executes the program, they should decide, by providing a command-line argument, on what the key should be in the secret message they’ll provide at runtime.
Demo
Specification
Design and implement a program, substitution, that encrypts messages using a substitution cipher.
- Implement your program in a file called substitution.cin a directory calledsubstitution.
- Your program must accept a single command-line argument, the key to use for the substitution. The key itself should be case-insensitive, so whether any character in the key is uppercase or lowercase should not affect the behavior of your program.
- If your program is executed without any command-line arguments or with more than one command-line argument, your program should print an error message of your choice (with printf) and return frommaina value of1(which tends to signify an error) immediately.
- If the key is invalid (as by not containing 26 characters, containing any character that is not an alphabetic character, or not containing each letter exactly once), your program should print an error message of your choice (with printf) and return frommaina value of1immediately.
- Your program must output plaintext:(without a newline) and then prompt the user for astringof plaintext (usingget_string).
- Your program must output ciphertext:(without a newline) followed by the plaintext’s corresponding ciphertext, with each alphabetical character in the plaintext substituted for the corresponding character in the ciphertext; non-alphabetical characters should be outputted unchanged.
- Your program must preserve case: capitalized letters must remain capitalized letters; lowercase letters must remain lowercase letters.
- After outputting ciphertext, you should print a newline. Your program should then exit by returning 0frommain.
You might find one or more functions declared in ctype.h to be helpful, per manual.cs50.io.
Walkthrough
How to Test
Correctness
check50 cs50/problems/2025/spring/substitution
How to Use debug50
Looking to run debug50? You can do so as follows, after compiling your code successfully with make,
debug50 ./substitution KEY
wherein KEY is the key you give as a command-line argument to your program. Note that running
debug50 ./substitution
will (ideally!) cause your program end by prompting the user for a key.
Style
style50 substitution.c
How to Submit
Per Step 4 below, after you submit, be sure to check your autograder results. If you see SUBMISSION ERROR: missing files (0.0/1.0), it means your file was not named exactly as prescribed (or you uploaded it to the wrong problem).
Correctness in submissions entails everything from reading the specification, writing code that is compliant with it, and submitting files with the correct name. If you see this error, you should resubmit right away, making sure your submission is fully compliant with the specification. The staff will not adjust your filenames for you after the fact!
- Download your substitution.cfile by control-clicking or right-clicking on the file in your codespace’s file browser and choosing Download.
- Go to CS50’s Gradescope page.
- Click Problem Set 2: Substitution.
- Drag and drop your substitution.cfile to the area that says Drag & Drop. Be sure it has that exact filename! If you upload a file with a different name, the autograder likely will fail when trying to run it. Ensuring you have uploaded files with the correct filename is your responsibility!
- Click Upload.
You should see a message that says “Problem Set 2: Substitution submitted successfully!”