Я написал небольшую программу для Ceasar cipher в C++. Я думаю, что я хорошо разбираюсь в логике. Однако добавление ASCII идет не так по какой-то нечетной причине, которую я не могу понять. Вот мой код: Что-то не так в этой строке: "s [i] = (abs (s [i])) + k;"Абсолютное значение не добавляется правильно в ascii
Я даю вход следующим образом:
ху
Выход Должно быть: Г.Х.
Я получаю результат, как: Под ред.
#include <cmath>
#include <cstdio>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
int main(){
int n;
cin >> n;
string s;
cin >> s;
int k;
cin >> k;
k = k % 26;
for(int i = 0; i<s.size(); i++){
if((abs(s[i]) >=65 && abs(s[i]) <=90) || (abs(s[i]) >= 97 && abs(s[i]) <= 122)){
cout << "k is: "<<k << endl; //k should be 9
//for x abs(s[i]) should be 120
cout << "Absolute value is: "<<abs(s[i]) <<endl;
s[i] = (abs(s[i])) + k; // thish is not 129.. i am getting 127
cout << "After adding K: "<<abs(s[i]) << endl;
if((abs(s[i]) > 90) && (abs(s[i]) < 97))
s[i] = abs(s[i]) - 26;
if(abs(s[i]) > 122){
s[i] = abs(s[i]) - 26;
}
}
}
for(int i =0 ; i< s.size(); i++)
cout<<s[i];
return 0;
}
Любая помощь будет оценена по достоинству. Благодарю.
Строка из подписанных символов справа? поэтому 129 - это не-гость. –
О, ладно, я пропустил это. Какой бы быстрый способ решить эту проблему? – hshantanu
проверить мой ответ :) –