Steganography, as defined by Webster’s Dictionary, is the art or practice of concealing a message, image, or file within another message, image, or file. For this week’s assignment we are going to work with arrays, strings, and StringBuilder to decode a message that has been hidden inside another file and sent to us from our friend, Randy Waterhouse (you have my sincere admiration if you get that reference!). Randy is sending us a message that he has encoded within a regular data file. This means he has taken the file and changed random characters within that file that will spell out a message if we can figure out which characters he changed and the ordered in which he changed them.
The original file looked like this:
Randy then went line by line and changed certain characters according to the below table. The lines and columns of the table are indexed starting at zero, just like our arrays in C#. The first entry in the table, “0,5=n” means that Randy changed the character in line zero at the 5th letter (which is actually the 6th since we started at zero) to be “n” (it was originally “W”). Here is the table of changes that Randy made. Note that he only changed 5 characters per line and that each line has 60 characters in it:
And here is the new data with Randy’s changes:
If we know the order that he changed the characters in each line, we can create the following four strings of five characters each:
If we append all those strings together from top to bottom, we will have the full message that Randy sent us (apparently Randy is a fan of the movie “A Christmas Story”):
Drink more Ovaltine!
So how do we figure out the order? Many cryptographic systems have two main components: an equation and a key. The equation generates a string of numbers based on the key number that is plugged in to that equation (that’s a super-simple explanation, but this isn’t a crypto class, so…). In this case, Randy kept it simple. He’s a C# programmer, after all! He used the Random class as his equation, and he knows that using a certain number as a “seed” or “key” will make Random generate the same sequence of numbers when “next” is called. If Randy tells you the seed, and you know that he did his encryption line by line, then you can get the characters from Randy’s seemingly random data and generate the message.
The attached assignment shell has an array of 22 strings already declared for you that represent the lines in a data file. Each line has 60 characters in it, but Randy only changed 5 of those characters. You need to use nested for loops (i.e. one for loop inside another) and Random’s “next” method to pull the five characters from each line and store those in a different array of strings, where each string is 5 characters long. Remember, if you seed your Random with the same number Randy did, then your “next” will generate the same sequence of numbers. Those numbers are the indices of the characters you need to get from each line. Once you have put the five characters from each line into your array, you need to call your printIt method. Your printIt method should take the array of decrypted characters as input. It should first print the contents of that array to the screen (there should be 22 lines of 5 characters each). Then it should use a StringBuilder to put those 22 lines together into something that is more readable. DO NOT simply “+=” each of the 22 strings into a larger string. You must use StringBuilder. Finally, print the contents of your StringBuilder to the screen – you should see the message that Randy hid in the data file. For full credit, you must also include the message as part of your submission text for this assignment!
You need to seed your random number generator with 243 because that’s the number Randy used when encrypting his message (he chose that because 243 would generate 22 5-character sequences where those 5 characters would not repeat).
We value our customers and so we ensure that what we do is 100% original..
With us you are guaranteed of quality work done by our qualified experts.Your information and everything that you do with us is kept completely confidential.
You have to be 100% sure of the quality of your product to give a money-back guarantee. This describes us perfectly. Make sure that this guarantee is totally transparent.Read more
The Product ordered is guaranteed to be original. Orders are checked by the most advanced anti-plagiarism software in the market to assure that the Product is 100% original. The Company has a zero tolerance policy for plagiarism.Read more
The Free Revision policy is a courtesy service that the Company provides to help ensure Customer’s total satisfaction with the completed Order. To receive free revision the Company requires that the Customer provide the request within fourteen (14) days from the first completion date and within a period of thirty (30) days for dissertations.Read more
The Company is committed to protect the privacy of the Customer and it will never resell or share any of Customer’s personal information, including credit card data, with any third party. All the online transactions are processed through the secure and reliable online payment systems.Read more
By placing an order with us, you agree to the service we provide. We will endear to do all that it takes to deliver a comprehensive paper as per your requirements. We also count on your cooperation to ensure that we deliver on this mandate.Read more