У меня возникли проблемы с созданием функции, которая шифрует слово, используя номер вращения, который вводит пользователь. Вот то, что я до сих пор:C++ шифрование с вращением
string encryptWord(string word, int num)
{
string newWord;
newWord = word;
for(int i = 0; i < word.length(); i++)
{
newWord[i] = tolower(word[i]);
if((word[i] >= 'a') && (word[i] <= 'z'))
{
newWord[i] = word[i] + (num % 26);
if(newWord[i] > 'z')
newWord[i] = newWord[i] - 26;
}
}
return newWord;
}
теперь мой главный, когда я проверить его с
cout << encryptWord("xyz", 6);
выход я получаю: от
Аналогично, для дешифрования У меня есть
string decryptRotWord(string word, int num)
{
string newWord;
num = num % 26;
int index;
for(int i = 0; i < word[i]; i++)
{
newWord[i] = tolower(word[i]);
if(word[i] >= 'a' && word[i] <= 'z')
{
index = word[i] - num;
if(index < 'a')
index = index + 26;
newWord[i] = index;
}
}
return newWord;
}
Однако для этого один ничего не выводит, когда я тестирую
cout << decryptRotWord("vdds", 2);
' 'г' + 6> CHAR_MAX'. Ваша программа демонстрирует неопределенное поведение, посредством подписанного интегрального переполнения. –
Вот почему я нахожу TDD быстрее для разработки кода с любой логикой в нем. – cgarner
EDIT ah, my bad :( – Zereges