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
255de 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;
}