কম্পিউটার

ভিজেনার সাইফার বাস্তবায়নের জন্য C++ প্রোগ্রাম


Vigenere Cipher হল বর্ণমালার টেক্সট এনক্রিপ্ট করার এক ধরনের পলিঅ্যালফাবেটিক প্রতিস্থাপন পদ্ধতি।

এই পদ্ধতিতে এনক্রিপশন এবং ডিক্রিপশনের জন্য Vigenere Cipher Table ব্যবহার করা হয় যেখানে A থেকে Z বর্ণমালা 26 সারিতে লেখা হয়।

ভিজেনার সাইফার বাস্তবায়নের জন্য C++ প্রোগ্রাম

এনক্রিপশন

কী: স্বাগতম

বার্তা: এইসিস্ট্যুটোরিয়ালপয়েন্ট

এখানে আমাদের প্রদত্ত কী পুনরাবৃত্তি করে একটি কী পেতে হবে যতক্ষণ না এর দৈর্ঘ্য মূল বার্তার দৈর্ঘ্যের সমান হয়৷

এনক্রিপশনের জন্য বার্তার প্রথম অক্ষর এবং কী যেমন T এবং W নিন। Vigenere Cipher Table-এ বর্ণমালা নিন যেখানে T সারি এবং W কলাম মিলে যায় অর্থাৎ P.

বার্তা পাঠে অবশিষ্ট সমস্ত বর্ণমালার জন্য একই প্রক্রিয়া পুনরাবৃত্তি করুন।

অবশেষে, এনক্রিপ্ট করা বার্তা পাঠ্য হল −

এনক্রিপ্ট করা বার্তা: PLTUWEXQXZTWMPOTZKBF।

সাইফার টেক্সট নিচের সমীকরণ দ্বারা তৈরি করা যেতে পারে।

Ei =(Pi + Ki) mod 26

এখানে P হল প্লেইন টেক্সট এবং K হল কী।

ডিক্রিপশন

কী: স্বাগতম

এনক্রিপ্ট করা বার্তা: PLTUWEXQXZTWMPOTZKBF

জেনারেট করা কী এবং এনক্রিপ্ট করা বার্তার প্রথম বর্ণমালা যেমন P এবং W নিন। Vigenere Cipher Table বিশ্লেষণ করুন, W কলামে P বর্ণমালা খুঁজুন, সংশ্লিষ্ট সারিটি হবে মূল বার্তার প্রথম বর্ণমালা অর্থাৎ T.

এনক্রিপ্ট করা বার্তায় সমস্ত বর্ণমালার জন্য এই প্রক্রিয়াটি পুনরাবৃত্তি করুন৷

মূল বার্তা:Thisistutorialspoint

এই সমীকরণ অনুসরণ করে বীজগণিত আকারে উপস্থাপন করা যেতে পারে।

Pi =(Ei – Ki + 26) mod 26

এখানে Vigenere সাইফার বাস্তবায়নের জন্য একটি C++ প্রোগ্রাম রয়েছে।

অ্যালগরিদম

Begin
   Function encryption(string t)
   for i = 0, j = 0 to t.length() - 1
      char c = t[i]
      if (c >= 'a' and c <= 'z')
         c = c + 'A' - 'a'
      else if (c < 'A' or c > 'Z')
         continue
      output = output + (c + k[j] ) % 26 + 'A'
      j = (j + 1) % k.length()
   return output
End
Begin
   Function decryption(string t)
   for i = 0, j = 0 to t.length() - 1
      char c = t[i]
      if (c >= 'a' and c <= 'z')
         c = c + 'A' - 'a'
      else if (c < 'A' or c > 'Z')
         continue
      output =output + (c - k[j] + 26) % 26 + 'A'
      j = (j + 1) % k.length()
   return output
End

উদাহরণ

#include <iostream>
#include <string>
using namespace std;
class Vig {
   public:
      string k;
   Vig(string k) {
      for (int i = 0; i < k.size(); ++i) {
         if (k[i] >= 'A' && k[i] <= 'Z')
            this->k += k[i];
         else if (k[i] >= 'a' && k[i] <= 'z')
            this->k += k[i] + 'A' - 'a';
      }
   }
   string encryption(string t) {
      string output;
      for (int i = 0, j = 0; i < t.length(); ++i) {
         char c = t[i];
         if (c >= 'a' && c <= 'z')
            c += 'A' - 'a';
         else if (c < 'A' || c > 'Z')
            continue;
         output += (c + k[j] - 2 * 'A') % 26 + 'A'; //added 'A' to bring it in range of ASCII alphabet [ 65-90 | A-Z ]
         j = (j + 1) % k.length();
      }
      return output;
   }
   string decryption(string t) {
      string output;
      for (int i = 0, j = 0; i < t.length(); ++i) {
         char c = t[i];
         if (c >= 'a' && c <= 'z')
            c += 'A' - 'a';
         else if (c < 'A' || c > 'Z')
            continue;
         output += (c - k[j] + 26) % 26 + 'A';//added 'A' to bring it in range of ASCII alphabet [ 65-90 | A-Z ]
         j = (j + 1) % k.length();
      }
      return output;
   }
};
int main() {
   Vig v("WELCOME");
   string ori ="Thisistutorialspoint";
   string encrypt = v.encryption(ori);
   string decrypt = v.decryption(encrypt);
   cout << "Original Message: "<<ori<< endl;
   cout << "Encrypted Message: " << encrypt << endl;
   cout << "Decrypted Message: " << decrypt << endl;
}

আউটপুট

Original Message: Thisistutorialspoint
Encrypted Message: PLTUWEXQXZTWMPOTZKBF
Decrypted Message: THISISTUTORIALSPOINT

  1. ভিজেনার সাইফার বাস্তবায়নের জন্য C++ প্রোগ্রাম

  2. সিজার সাইফার বাস্তবায়নের জন্য C++ প্রোগ্রাম

  3. AVL ট্রি বাস্তবায়নের জন্য C++ প্রোগ্রাম

  4. STL-এ সেট_সিমেট্রিক_ডিফারেন্স বাস্তবায়নের জন্য C++ প্রোগ্রাম