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

  Create program that uses functions and reference parameters

Create program that uses functions and reference parameters, and asks user for the outside temperature.

  Write a program using vectors and iterators

Write a program using vectors and iterators that allows a user to maintain a personal list of DVD titles

  Write the code required to analyse and display the data

Calculate and store the average for each row and column. Determine and store the values for the Average Map.

  Write a webservices application

Write a webservices application that does a simple four function calculator

  Iimplement a client-server of the game

Iimplement a client-server version of the rock-paper-scissors-lizard-Spock game.

  Model-view-controller

Explain Model-View-Controller paradigm

  Design a nested program

How many levels of nesting are there in this design?

  Convert celsius temperatures to fahrenheit temperatures

Write a C++ program that converts Celsius Temperatures to Fahrenheit Temperatures.

  Evaluate and output the value in the given base

Write C program that will input two values from the user that are a Value and a Base with which you will evaluate and output the Value in the given Base.

  Design a base class shape with virtual functions

Design a base class shape with virtual functions

  Implementation of classes

Implementation of classes Chart and BarChart. Class barChart chould display a simple textual representation of the data

  Technical paper: memory management

Technical Paper: Memory Management, The intent of this paper is to provide you with an in depth knowledge of how memory is used in executing, your programs and its critical support for applications.

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