Rozwiązane

Zadanie w C++
Napisz program, który podany przez użytkownika tekst jawny, zapisany bez spacji, będzie szyfrować wybranym przez niego szyfrem: albo metodą kolumnową, albo szyfrem Cezara. Wybór szyfru powinien być dokonywany już po uruchomieniu programu.



Odpowiedź :

Mam nadzieje ze dobrze

// Szyfrowanie dla słów złożonych z liter alfabetu łacińskiego.

#include <iostream>

#include <string>

using namespace std;

   char znaki[2][52] =    {{'q', 'w', 'e', 'r', 't', 'y', 'u', 'i', 'o', 'p', 'a', 's', 'd', 'f', 'g', 'h', 'j',

                            'k', 'l', 'z', 'x', 'c', 'v', 'b', 'n', 'm', 'Q', 'W', 'E', 'R', 'T', 'Y', 'U', 'I',

                            'O', 'P', 'A', 'S', 'D', 'F', 'G', 'H', 'J', 'K', 'L', 'Z', 'X', 'C', 'V', 'B', 'N', 'M'},

               {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U',

               'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm',

               'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'}};

string szyfruj(string slowo)

{

   string slowo2 = slowo;

   for(int x=0;x<slowo.length();x++)

   {

       

       slowo2[x] = '~';

       for(int y=0;y<52;y++)

       {

           if(slowo[x]==znaki[1][y])

           {

               slowo2[x] = znaki[0][y];

               break;

           }

       }

   }

   return slowo2;

}

string odszyfruj(string slowo)

{

   string slowo2 = slowo;

   for(int x=0;x<slowo.length();x++)

   {

       

       slowo2[x] = '~';

       for(int y=0;y<52;y++)

       {

           if(slowo[x]==znaki[0][y])

           {

               slowo2[x] = znaki[1][y];

               break;

           }

       }

   }

   return slowo2;

}

int main()

{

   cout << szyfruj("ALA") << endl;

   cout << odszyfruj("qsq")<< endl;

   system("pause");

   return 0;

}