Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на Delphi и Lazarus


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

lamed
Статус: Практикант
Рейтинг: 2151
∙ повысить рейтинг »
Boriss
Статус: Академик
Рейтинг: 1775
∙ повысить рейтинг »
Jimhucksly
Статус: 5-й класс
Рейтинг: 609
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Программирование / Delphi и Lazarus

Номер выпуска:1494
Дата выхода:17.02.2010, 01:30
Администратор рассылки:Калашников О.А., Руководитель
Подписчиков / экспертов:551 / 227
Вопросов / ответов:1 / 1

Вопрос № 176634: Добрый день уважаемые эксперты! Прошу у вас в помощи в написании кода на Дельфи! Нужно: Модифицировать приведенную в примере программу так, чтобы вместо шифра Цезаря использовалась аффинная подстановка Цезаря. Пример программы в приложе...



Вопрос № 176634:

Добрый день уважаемые эксперты!
Прошу у вас в помощи в написании кода на Дельфи!
Нужно:
Модифицировать приведенную в примере программу так, чтобы вместо шифра Цезаря использовалась аффинная подстановка Цезаря.
Пример программы в приложении!
Заранее огромное спасибо!!!

Отправлен: 12.02.2010, 01:01
Вопрос задал: Андреев Дмитрий Фёдорович, Посетитель
Всего ответов: 1
Страница вопроса »


Отвечает star9491, 6-й класс :
Здравствуйте, Андреев Дмитрий Фёдорович.

Вообще то ascii-коды плохо подходят для шифрования текста так как нужно либо цикличеки продолжить алфавит либо пересчитывать номер символа когда он выходит за пределы алфавита. Советую разделить процеccы отображения символов и их шифрования и написать сначала две процедуры, которые переводят символы в коды и обратно. Что-то типа этого:

Код:
function CharToCode(ch:Char):Integer;
begin
case ch of
'А':Result:=0;
....................
'Я':Result:=30;
' ':Result:=31;
else Result:=-1;
end;
end;

function CodeToChar(code:Integer):Char;
begin
case code of
0:Result:='А';
.....................
30:R esult:='Я';
31:Result:=' ';
else Result:=#0;
end;
end;


После этого шифрование осуществляется просто по формуле:
code:=(a*code+b) mod n
(a и b взаимно просты, а n - число символов в алфавите).

Возможный вариант фрагмента шифрования:

Код:
const
a=13;
b=5;
n=32;

var
s:string;
............................................
while not eof(InFile) do
begin
Read(inFile,Symbol);
s:=AnsiUpperCase(Symbol);
code:=CharToCode(s[1]);
code:=(a*code+b) mod n;
Symbol:=CodeToChar(code);
Write(outFile,Symbol);
end;
.......................................

Ответ отправил: star9491, 6-й класс
Ответ отправлен: 12.02.2010, 23:37
Номер ответа: 259411

Вам помог ответ? Пожалуйста, поблагодарите эксперта за это!
Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 259411 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:

  • Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2010, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2010.6.14 от 03.02.2010

    В избранное