Build a method for performing frequency analysis

Assignment Help C/C++ Programming
Reference no: EM13702679

At the conclusion of this programming assignment, participants should be able to:

Design, implement and test classes in C++

Apply and implement overloaded operators and functions

Design and implement classes using inheritance

Parts of this assignment are courtesy of Jack Hagemeister.

Security and secrecy are popular topics in computer science. Every nation in the world has struggled with the task of communicating important information to its allies and armies at the same time trying to keep that information secret from others. In this assignment, you will be implementing some simple ciphers from history and look at ways to "decode" them. You will find that the use of modern computers makes decoding of some of these very easy.

You should first review some information about ciphers. Start at the following web site, Codes, Ciphers, &Codebreaking. It has an excellent introduction into the classic / historical Ciphers. You will need to read at least the first section, but I recommend reading sections 2 and 3 as well.

These sections include: "1.0: Introduction to Codes, Ciphers, &Codebreaking", "2.0: Refining the Art", and "3.0 The Rise of Field Ciphers".

You will design objects for each of the two encryption techniques required. Each object should hold a message that is either "clear text" or "encrypted".

You should be able to create any object around a string of text and an indicator of its status. You should have methods to retrieve the clear text or encrypted message from the object no matter how it is stored. Ok, so there are some other issues. If you have an encoded message and do not know the key in the Caesar Cipher or the substitution cipher you need methods to interact with the message to try and determine the key.

For the Caesar Cipher this is simply being able to test each key number from 1 through 25. You probably do not even have to do anything special except in the calling program. For the substitution cipher, you will have to have a method that does frequency analysis, and gives you a best guess. You may want to be able to put in substitutions as well to correct any problems that you find in the analysis.

1. Build a basic cipher base class that may be derived from for the ciphers described below.

2. Encode a text message using the Caesar Cipher, a mono-alphabetic substitution cipher. You will need to input the KEY number from 1 to 25. Do not encode special characters or white space. All encoded text should be upper case only. You should be able to save an encoded message to a file.

3. Decode a Caesar Cipher text. You will have two cases:

a. You are given the KEY.
b. You have to break the KEY by brute force trial and error.

4. Build a randomly generated simple substitution cipher and use it to encode messages. Again the encoded messages will be in all upper case letters only. Only encode the letters.

5. Build a method for performing frequency analysis to decode a substitution cipher. Your system should determine the frequency of characters in the encoded message and generate its guess on the decoding by building a lookup table as an array and supporting class that would hold each encoded pair of characters.

6. Build a standard text-based wrapper/class for the application.

Reference no: EM13702679

Questions Cloud

What magnitude of force does one line of charge exert : Two very long uniform lines of charge are parallel and are separated by 0.240m. Each line of charge has charge per unit length 5.10 C/m. What magnitude of force does one line of charge exert on a 5.00×102 m section of the other line of charge
What is the acceleration : A car moving along a staight road uniformly slows down to a speed of (5 + 0.4x) m/s in 10 seconds. During this time the car travels (150 +x) m. What is the acceleration
Find the electric field just outside the paint layer : A charged paint is spread in a very thin uniform layer over the surface of a plastic sphere of diameter 17.0 cm, giving it a charge of -16.0 µC. Find the electric field just outside the paint layer
What is its average velocity : Velocity of a moving particle is expressed by v = 2t2-t3, where y is in m and t is in seconds. What is its average velocity between t=0 and t=2seconds
Build a method for performing frequency analysis : Build a basic cipher base class that may be derived from for the ciphers and decode a Caesar Cipher text. You will have two cases.
Estimate the density of the metal : A circular metal plate has a radius of (60 + x ) cm, a thickness of 15 cm and a mass of 900 kg. What is the density of the metal
How much water is left in the container : A large container holding 340g of water, initially at 14°C is placed in a microwave oven. How much water is left in the container
Find the angle and the initial velocity of the ball : Hypothetically, you are standing on the balcony of an apartment on the 10th level of a building and you throw a ball at some angle, Î, above the horizontal away from the building. Find the angle and the initial velocity of the ball
Write an expression for the time it takes for each ball : A student at the top of a building of height h throws one ball straight upward with an initial speed of v0. Write an expression for the time it takes for each ball

Reviews

Write a Review

C/C++ Programming Questions & Answers

  Write a function to compute the magnitude f

write a function to compute the magnitude F and direction angle of a two-dimensional force F by using two components of the force fx,fy as its parameters,returning F and using the reference to pass theta value .

  Consists of an employee''s last name

Each input line consists of an employee's last name, first name, current base salary, total sales and percent commission. For example, in the first input line, the last name of the employee is Thomas, the first name is Andrew, the current base salary..

  Write a test program to test the various operations

Write the definitions of the member functions as described in the definition of the class testClass.

  Algorithm to determine which items to take to max weight

Write an algorithm to determine which items to take to maximize the weight of his loot bag. He cannot take a fraction of an item and each item must be taken, or left behind. Loot bag size is Z and and the input is an array of item wieghts as integers..

  Implement a class called hugeinteger

Using your own Linked List implementation (see attached), implement a class called HugeInteger that represents arbitrary sized integers and supports addition only. You may only use the tools that have introduced in class, and you MAY NOT use Java'..

  Display a count of the number of vowels

Write a program that accepts a word into a character array string variable. Display a count of the number of letters in the word.

  Design your application according to the considerations

Design your application according to the considerations described above.  For example, you must use functions that have the specified signatures, and arrays that have the specified declarations. They are

  Display the array, the average and the number of days above

Write a program that stores the daily temperatures for the month of April in an array name dailytemp. Calculate the average temperature for the month and the count the number of days that the daily temperature was above the average.

  Design and implement a class called bus

Define the Bus constructor to accept and initialize all instance data. Include getter and setter methods for all instance data.

  Write a function that permanently swaps two floats

Write a function that permanently swaps two floats using references.

  The array is sorted except the first one

the array is sorted except the first one

  Write c program that prompts for variable number of integers

Write a C program that prompts for a variable number of integers, adds them up, averages them, and prints out the average.

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd