Lab #5. Task 1: You Need To Encrypt The Following Example:: Vigenere Vigenere

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 6

Lab #5.

Task 1 : You need to encrypt the following example:

Keyword: pen

Plaintext: theater

using Vigenère Cipher.

Task 2 : Give some keyword and encrypt your last name


For example:
Key: APPLE
Plaintext: IVANOV

using Vigenere Cipher.


Vigenere Cipher
Vigenere Cipher is a method of encrypting alphabetic text. It uses a simple form
of polyalphabetic substitution. A polyalphabetic cipher is any cipher based on
substitution, using multiple substitution alphabets .The encryption of the original
text is done using the  Vigenere square or Vigenere table.
 The table consists of the alphabets written out 26 times in different rows, each
alphabet shifted cyclically to the left compared to the previous alphabet,
corresponding to the 26 possible Caesar Ciphers.
 At different points in the encryption process, the cipher uses a different
alphabet from one of the rows.
 The alphabet used at each point depends on a repeating keyword.

 Example:
 Input : Plaintext : GEEKSFORGEEKS
 Keyword : AYUSH
 Output : Ciphertext : GCYCZFMLYLEIM
 For generating key, the given keyword is repeated
 in a circular manner until it matches the length of
 the plain text.
 The keyword "AYUSH" generates the key "AYUSHAYUSHAYU"
 The plain text is then encrypted using the process
 explained below.
Encryption
The first letter of the plaintext, G is paired with A, the first letter of the key. So use
row G and column A of the Vigenere square, namely G. Similarly, for the second
letter of the plaintext, the second letter of the key is used, the letter at row E and
column Y is C. The rest of the plaintext is enciphered in a similar fashion.

Decryption
Decryption is performed by going to the row in the table corresponding to the key,
finding the position of the ciphertext letter in this row, and then using the column’s
label as the plaintext. For example, in row A (from AYUSH), the ciphertext G
appears in column G, which is the first plaintext letter. Next we go to row Y (from
AYUSH), locate the ciphertext C which is found in column E, thus E is the second
plaintext letter.
A more easy implementation could be to visualize Vigenere algebraically by
converting [A-Z] into numbers [0–25].
Encryption
The plaintext(P) and key(K) are added modulo 26.
Ei = (Pi + Ki) mod 26

Decryption
Di = (Ei - Ki + 26) mod 26

Note: Di denotes the offset of the i-th character of the plaintext. Like offset of A is
0 and of B is 1 and so on.
Below is the implementation of the idea.
In C++:

// C++ code to implement Vigenere Cipher


#include<bits/stdc++.h>
using namespace std;

// This function generates the key in


// a cyclic manner until it's length isi'nt
// equal to the length of original text
string generateKey(string str, string key)
{
int x = str.size();

for (int i = 0; ; i++)


{
if (x == i)
i = 0;
if (key.size() == str.size())
break;
key.push_back(key[i]);
}
return key;
}

// This function returns the encrypted text


// generated with the help of the key
string cipherText(string str, string key)
{
string cipher_text;

for (int i = 0; i < str.size(); i++)


{
// converting in range 0-25
char x = (str[i] + key[i]) %26;

// convert into alphabets(ASCII)


x += 'A';

cipher_text.push_back(x);
}
return cipher_text;
}

// This function decrypts the encrypted text


// and returns the original text
string originalText(string cipher_text, string key)
{
string orig_text;

for (int i = 0 ; i < cipher_text.size(); i++)


{
// converting in range 0-25
char x = (cipher_text[i] - key[i] + 26) %26;

// convert into alphabets(ASCII)


x += 'A';
orig_text.push_back(x);
}
return orig_text;
}

// Driver program to test the above function


int main()
{
string str = "GEEKSFORGEEKS";
string keyword = "AYUSH";
string key = generateKey(str, keyword);
string cipher_text = cipherText(str, key);

cout << "Ciphertext : "


<< cipher_text << "\n";

cout << "Original/Decrypted Text : "


<< originalText(cipher_text, key);
return 0;
}

Output:
Ciphertext : GCYCZFMLYLEIM
Original/Decrypted Text : GEEKSFORGEEKS

You might also like