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
#include <bits/stdc++.h> using namespace std; int main() { char s[300]; cin.getline(s , 300); int n; cin >> n; int i = 0; while(s[i]!='\0') { if(s[i] >= 'a' && s[i] <= 'z') { if((int)s[i]+n > 122) cout << (char)((int)s[i]+n-26); else cout << (char)((int)s[i]+n); } else cout << s[i]; i++; } return 0; }