You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Add encryption and decryption programs for four-digit integers
This commit adds two C programs: one for encrypting a four-digit integer and another for decrypting the encrypted integer back to the original number. The encryption program replaces each digit with (digit + 7) % 10, swaps the first and third digits, and swaps the second and fourth digits. The decryption program reverses these steps by using (digit + 3) % 10 for decryption, then swaps the digits back to their original positions.
// (Enforcing Privacy with Cryptography) The explosive growth of Internet communications and data storage on Internet-connected computers has greatly increased privacy concerns. The field of cryptography is concerned with coding data to make it difficult (and hopefully—with the most advanced schemes—impossible) for unauthorized users to read. In this exercise you’ll investigate a simple scheme for encrypting and decrypting data. A company that wants to send data over the Internet has asked you to write a program that will encrypt it so that it may be transmitted more securely. All the data is transmitted as four-digit integers. Your application should read a four-digit integer entered by the user and encrypt it as follows: Replace each digit with the result of adding 7 to the digit and getting the remainder after dividing the new value by 10. Then swap the first digit with the third, and swap the second digit with the fourth. Then print the encrypted integer. Write a separate application that inputs an encrypted four-digit integer and decrypts it (by reversing the encryption scheme) to form the original number. [Optional reading project: Research “public key cryptography” in general and the PGP (Pretty Good Privacy) specific public key scheme. You may also want to investigate the RSA scheme, which is widely used in industrial-strength applications.]
// Each digit of the input number is replaced with (digit + 7) % 10.The first digit is swapped with the third, and the second digit is swapped with the fourth to get the encrypted number.
93
+
94
+
// Decryption:
95
+
// The process reverses the encryption steps. Since (digit + 7) % 10 is used for encryption, and we need to reverse this, we use (digit + 3) % 10 for decryption. This works because adding 3 undoes the original addition of 7 when considering modulo 10 arithmetic (since 10 - 7 = 3). Digits are swapped back to their original positions.
0 commit comments