Шифр Цезаря

Шифр Цезаря — один из древнейших шифров. При шифровании каждый символ заменяется другим, отстоящим от него в алфавите на фиксированное число позиций. Шифр Цезаря можно классифицировать как шифр подстановки, при более узкой классификации — шифр простой замены.


Шифр назван в честь римского императора Гая Юлия Цезаря, использовавшего его для секретной переписки. Естественным развитием шифра Цезаря стал шифр Виженера. С точки зрения современного криптоанализа, шифр Цезаря не имеет приемлемой стойкости.


 Вот мой вариант реализации на С++:

#define SIZE 26

const char low_char[] = {'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'};

const char high_char[] = {'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'};

//
// Crypt algorithm
//
std::string crypt(std::string &InputString, int key){
bool OK;
std::string OutputString;
for(unsigned i=0; i OK=false;
for(int j=0; j if (InputString[i] == low_char[j]){
j += key;
while (j >= SIZE) j -= SIZE;
while (j < 0) j += SIZE;
OutputString += low_char[j];
OK=true;
break;
}
if (InputString[i] == high_char[j]) {
j += key;
while (j >= SIZE) j -= SIZE;
while (j < 0) j += SIZE;
OutputString += high_char[j];
OK=true;
break;
}
}
if(!OK)
OutputString +=InputString[i];
}
return OutputString;
}

//
// Decrypt algorithm
//
std::string decrypt(std::string &InputString, int key){
bool OK;
std::string OutputString;
for(unsigned i=0; i OK=false;
for(int j=0; j if (InputString[i] == low_char[j]){
j -= key;
while (j >= SIZE) j -= SIZE;
while (j < 0) j += SIZE;
OutputString += low_char[j];
OK=true;
break;
}
if (InputString[i] == high_char[j]) {
j -= key;
while (j >= SIZE) j -= SIZE;
while (j < 0) j += SIZE;
OutputString += high_char[j];
OK=true;
break;
}
}
if(!OK)
OutputString +=InputString[i];
}
return OutputString;
}