Cerința
În criptografie, cifrul Caesar este una dintre cele mai simple și mai cunoscute modalități de criptare a unui text. Este un cifru cu substituție, în care fiecare literă textul inițial este înlocuită cu o literă care se află în alfabet la o distanță fixă față de cea înlocuită. Această metodă este numită așa după Iulius Cezar, care o folosea pentru a comunica cu generalii săi.
De exemplu, cu o deplasare de 3
poziții, A
este înlocuit cu D
, B
devine E
și așa mai departe – în final X
devine A
, Y
devine B
, Z
devine C
. Celelalte caractere din text rămân nemodificate. Astfel, textul ana are mere
devine dqd duh phuh
.
Să se scrie un program care citește un text și un număr reprezentând deplasarea și îl criptează folosind cifrul Cezar cu deplasarea dată.
Date de intrare
Programul citește de la tastatură textul dat și valoarea deplasării, separate printr-un caracter newline
.
Date de ieșire
Programul va afișa pe ecran șirul criptat
Restricții și precizări
- șirul citit va avea cel mult
255
de caractere, în care nu apar litere mari - deplasarea este un număr natural cuprins între
1
și25
.
Exemplu
Intrare
ana are mere 3
Ieșire
dqd duh phuh
Cum e corect?
cout < "As la info";
cout << "As la info";
cout >> "As la info";
Felicitări! Poți mai mult?
Avem sute de probleme pentru tine, fiecare cu explicații ușor de înțeles.
Greșit, dar nu-i bai!
Antrenează-te cu sutele de probleme pe care ți le-am pregătit. Îți explicăm fiecare problemă în parte.
Rezolvare
Iată rezolvarea de 100 de puncte pentru problema Cezar:
#include <iostream>
#include <cstring>
using namespace std;
char s[256];
int n;
char dep[100];
int main()
{
cin.getline(s , 256);
cin >> n;
for(int i = 0 ; i < 26;i++)
dep[i] = dep[i+26] = i+'a';
for(int i = 0; s[i] ; i ++)
if(s[i] >= 'a' && s[i] <='z')
s[i] = dep[s[i] - 'a' + n];
cout << s;
return 0;
}
Atenție
Enunțurile afișate pe această pagină aparțin exclusiv site-ului PbInfo. Astfel, pentru ștergerea conținutului, puteți să ne contactați la adresa .
Rezolvarea problemei #903 Cezar
Pe această pagină găsești rezolvarea de 100 de puncte pentru problema #903 Cezar de pe PbInfo.ro. Atenție: nu încurajăm copiatul codului! Totuși, credem cu tărie că analizarea unei soluții corecte este o metodă foarte ușoară de a învăța informatică, astfel că oferim sursele pentru peste 1500 de probleme de pe platforma PbInfo.ro.
Pentru rezolvări PbInfo de la peste 1500 de probleme, vă invităm să intrați pe site-ul nostru!