Helloww
Helloww
Helloww
a b c d e f g h i j
0 1 2 3 4 5 6 7 8 9
k l m n o p q r s t
10 11 12 13 14 15 16 17 18 19
u v w x y z ,
20 21 22 23 24 25 26
Consider a cipher on the alphabet Z27 = {a, b, c, d… z, comma} as the table above the encryption
function with key (a, b):
C = aM + b (mod 27).
The program should accept the following parameters: a flag to indicate encryption or decryption,
a set of secret key, an input file name, and an output file name. For example:
myProgram -key a b -encrypt -in file1.txt -out file2.txt
myProgram -key a b -decrypt -in file2.txt -out file3.txt
The program should be able to detect invalid key and display an error message if it
encounters an invalid key.
Note: screen cap the programme output to demo your result; you may be asked to run your
submitted program in the tutorial.
Part 2.
Use statistical cryptanalysis to decrypt the following message. You must write down the steps.
[Answer without steps will not be given any mark.] (3 marks)
Message:
Jrqee seammtrn hidntw ypvt xytig afgk ryk dui jfg twid. Le’gi edt giraln wlge llvihtv kwe llfae
qyjxntwj bosic uog yiqac hvaikiin bn hidnt azal jpkxmpxvay bebt strjt, bjx wdr xx kd hpzv p
cweere px ndrzmev, dgsets lmca ctvkpicpp qeciwxt uvfb btmev ah ietrvc vufxgztni ees txqv
tfumtxecx rh pdwjxbai. Kwe qmxvehx npsii fu txqv pns ietrvc yppeieh djvzcg emtzue ees
dtpzkegc, nwec xyt dgset ih lfkegmev rpxytr ilrc mdzzcg. Wsmtrxrx xs cittshein sxrtt twijt dgsets
bep qe djktn sicxvtvzcg ilzcgh (pzze usfs ach stvtvrveh) xypt civs td fv zeex ddsipp jpgmxwt pru
coi hvaikiitd qc r eagetwuii fg sdqvihxrx.
Hints:
1. It’s written in English
2. All Punctuation is unchanged
3. All upper case characters in plaintext is kept in upper case in ciphertext; all lower case
characters in plaintext is kept in lower case in ciphertext
4. The length of key is in the range of 2 to 6.