Part 1:  Encryption   A. Using your FileReader, read the file "PlentyOfRoomAtTheBottom.txt" in the Labs Module.  There are non-printable characters in the file.  Sometimes FileReaders abort when encountering a non-printable or extended ASCII characters.  Handle this with exception handling if it happens.  Your program should continue processing instead of aborting.  Assign a specific character, of your choice, to the aborted character.   B. Using the rawdata from reading the "PlentyOfRoomAtTheBottom.txt", develop a frequency counter algorithm for each character the lower ASCII table. For example:   Character[  a  ] = Frequency[ 2475 ] Character[  b  ] = Frequency[ 420 ] Character[  c  ] = Frequency[ 985 ] C. Sort the Lower ASCII frequency characters (i.e. 1 to 128) in decending order and process the data by using your QTree algorithm.  Your QTree algorithm should be based on a PRIORITY_QUEUE. D. Create bit-trails, as defined in the Exercise Bit-Trail, for each character your QTree. E. For each character in the raw data file from part A, "lookup" each character in your QTree tuple list using your Tuple Search algorithm from Exercise Tuple and write the character's bit-trail in a file.  This encrypts the file in binary. Part 2:  Decryption A. For each encrypted character in the encrypted binary file, for example "01010010", walk the QTree by looping through the branches.   B. Start at the root of the QTree and "walk" the bit-trail until a Leaf Node is found.   C. A zero goes down the left branch and a one goes down the right branch.  The found Leaf Node will contain the Node.symbol at the end of the bit-trail. D. Write the Node.symbol to a decrypted file.  When complete, your original file, the PlentyOfRoomAtTheBottom.txt, will be decrypted and readable as plain text. E. In cases where the decrypted text is not readable, this implies your QTree is not constructed properly OR the bit-trail path is incorrect. You will need to debug your QTree and Bit-Trail algorithms. PlentyOfRoomAtTheBottom.txt "There's Plenty of Room at the Bottom by Richard P. Feynman  I imagine experimental physicists must often look with envy at men like Kamerlingh Onnes, who discovered a field like low temperature, which seems to be bottomless and in which one can go down and down. Such a man is then a leader and has some temporary monopoly in a scientific adventure. Percy Bridgman, in designing a way to obtain higher pressures, opened up another new field and was able to move into it and to lead us all along. The development of ever higher vacuum was a continuing development of the same kind.  I would like to describe a field, in which little has been done, but in which an enormous amount can be done in principle. This field is not quite the same as the others in that it will not tell us much of fundamental physics (in the sense of, "What are the strange particles?") but it is more like solid-state physics in the sense that it might tell us much of great interest about the strange phenomena that occur in complex situations. Furthermore, a point that is most important is that it would have an enormous number of technical applications.  What I want to talk about is the problem of manipulating and controlling things on a small scale.  As soon as I mention this, people tell me about miniaturization, and how far it has progressed today. They tell me about electric motors that are the size of the nail on your small finger. And there is a device on the market, they tell me, by which you can write the Lord's Prayer on the head of a pin. But that's nothing; that's the most primitive, halting step in the direction I intend to discuss. It is a staggeringly small world that is below. In the year 2000, when they look back at this age, they will wonder why it was not until the year 1960 that anybody began seriously to move in this direction.  Why cannot we write the entire 24 volumes of the Encyclopaedia Brittanica on the head of a pin?  Let's see what would be involved. The head of a pin is a sixteenth of an inch across. If you magnify it by 25,000 diameters, the area of the head of the pin is then equal to the area of all the pages of the Encyclopaedia Brittanica. Therefore, all it is necessary to do is to reduce in size all the writing in the Encyclopaedia by 25,000 times. Is that possible? "   Please write in C++, with your code. Just write the code that encrypt the file into binary, then decrypt it back into letters (it means the expected output would be the same with file .txt above)

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question
Part 1:  Encryption

 

A. Using your FileReader, read the file "PlentyOfRoomAtTheBottom.txt" in the Labs Module.  There are non-printable characters in the file.  Sometimes FileReaders abort when encountering a non-printable or extended ASCII characters.  Handle this with exception handling if it happens.  Your program should continue processing instead of aborting.  Assign a specific character, of your choice, to the aborted character.

 

B. Using the rawdata from reading the "PlentyOfRoomAtTheBottom.txt", develop a frequency counter algorithm for each character the lower ASCII table. For example:  
Character[  a  ] = Frequency[ 2475 ]
Character[  b  ] = Frequency[ 420 ]
Character[  c  ] = Frequency[ 985 ]

C. Sort the Lower ASCII frequency characters (i.e. 1 to 128) in decending order and process the data by using your QTree algorithm.  Your QTree algorithm should be based on a PRIORITY_QUEUE.

D. Create bit-trails, as defined in the Exercise Bit-Trail, for each character your QTree.

E. For each character in the raw data file from part A, "lookup" each character in your QTree tuple list using your Tuple Search algorithm from Exercise Tuple and write the character's bit-trail in a file.  This encrypts the file in binary.

Part 2:  Decryption

A. For each encrypted character in the encrypted binary file, for example "01010010", walk the QTree by looping through the branches.  

B. Start at the root of the QTree and "walk" the bit-trail until a Leaf Node is found.  

C. A zero goes down the left branch and a one goes down the right branch.  The found Leaf Node will contain the Node.symbol at the end of the bit-trail.

D. Write the Node.symbol to a decrypted file.  When complete, your original file, the PlentyOfRoomAtTheBottom.txt, will be decrypted and readable as plain text.

E. In cases where the decrypted text is not readable, this implies your QTree is not constructed properly OR the bit-trail path is incorrect. You will need to debug your QTree and Bit-Trail algorithms.


PlentyOfRoomAtTheBottom.txt

"There's Plenty of Room at the Bottom

by Richard P. Feynman 

I imagine experimental physicists must often look with envy at men like Kamerlingh Onnes, who discovered a field like low temperature, which seems to be bottomless and in which one can go down and down. Such a man is then a leader and has some temporary monopoly in a scientific adventure. Percy Bridgman, in designing a way to obtain higher pressures, opened up another new field and was able to move into it and to lead us all along. The development of ever higher vacuum was a continuing development of the same kind. 
I would like to describe a field, in which little has been done, but in which an enormous amount can be done in principle. This field is not quite the same as the others in that it will not tell us much of fundamental physics (in the sense of, "What are the strange particles?") but it is more like solid-state physics in the sense that it might tell us much of great interest about the strange phenomena that occur in complex situations. Furthermore, a point that is most important is that it would have an enormous number of technical applications. 

What I want to talk about is the problem of manipulating and controlling things on a small scale. 

As soon as I mention this, people tell me about miniaturization, and how far it has progressed today. They tell me about electric motors that are the size of the nail on your small finger. And there is a device on the market, they tell me, by which you can write the Lord's Prayer on the head of a pin. But that's nothing; that's the most primitive, halting step in the direction I intend to discuss. It is a staggeringly small world that is below. In the year 2000, when they look back at this age, they will wonder why it was not until the year 1960 that anybody began seriously to move in this direction. 

Why cannot we write the entire 24 volumes of the Encyclopaedia Brittanica on the head of a pin? 

Let's see what would be involved. The head of a pin is a sixteenth of an inch across. If you magnify it by 25,000 diameters, the area of the head of the pin is then equal to the area of all the pages of the Encyclopaedia Brittanica. Therefore, all it is necessary to do is to reduce in size all the writing in the Encyclopaedia by 25,000 times. Is that possible? "

 

Please write in C++, with your code. Just write the code that encrypt the file into binary, then decrypt it back into letters (it means the expected output would be the same with file .txt above)

Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 4 steps

Blurred answer
Knowledge Booster
Exception Handling Keywords
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education