Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.95/40: Рейтинг темы: голосов - 40, средняя оценка - 4.95
1 / 1 / 0
Регистрация: 13.05.2016
Сообщений: 27

Шифр Цезаря

18.10.2016, 09:28. Показов 8611. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
нужно написать программу, шифрующий строку шифром цезаря, причем задается произвольный сдвиг и алфавит в виде массива

Добавлено через 14 часов 32 минуты
написала программу, примерно так нужно, но она не работает

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
const M = 33;
var b: array [0..M-1] of char; 
   n: integer;
   s,k:string;
 
Begin
  writeln ('Введите предложение');
  readln (s);
  writeln ('Чему равен сдвиг?');
  readln (n); 
  write('Шифр Цезаря -> ');
  for var i := 1 to s.length do
    begin
      b[i-1]:= s[i];
      k := (b[i] + n) mod M;
     write(k);
    end;
  
End.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.10.2016, 09:28
Ответы с готовыми решениями:

Почему ml? Шифр Юлия Цезаря
var st : string; i : byte; begin Assign (input , 'input.txt'); Assign (output , 'output.txt'); ReSet (input);...

Шифр Цезаря (нужна блок-схема)
Программа шифрует вводимую строку "Шифром Цезаря",как построить ее блок-схему? Program Shifr; const n=25; {число букв в алфавите} ...

Расшифровка методом цезаря
Помогите написать программу для расшифровки методом цезаря расшифровать текст. Смещение 3 - Сзргйзю тсуцълн Уйиефнлм цкрго, ъхс зов...

10
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,059
18.10.2016, 11:31
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Сдвиг проще всего производить по строке–алфавиту:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
const
  ABC = 'абвгдеёжзийклмнопрстуфхцчшщъыьэюя';
  
begin
  var s0 := ReadLnString ('Введите строку:');
  var  n := ReadLnInteger('Ключевое число:');
  var s1 := ''; // это будет результат
  foreach var c : Char in s0 do // для каждого символа исходной строки
    if ABC.IndexOf(c) < 0 then // такого символа нет в алфавите
      s1 += c // поэтому просто перенесём его в результат
    else // есть такой символ в алфавите
      begin
        var p := (ABC.Length + ABC.IndexOf(c) + n) mod ABC.Length + 1; // позиция зашифрованного символа
        s1 += ABC[p]; // зашифрованный символ в строку результата
      end;
  WriteLn('Зашифрованное сообщение: ', s1);
end.
Проверял вот для таких данных:
Code
1
2
3
4
5
мама мыла раму
+5
сесе саре хесш
-5
мама мыла раму
Формула для вычисления позиции нового символа:
ABC.IndexOf(c) — получаем позицию символа в алфавите („а“ – это 0, „я“ – это 32)
n — смещение (если отрицательное значение, то не должно превышать размера алфавита по модулю [для этого добавляется длина строки алфавита ABC.Length])
mod ABC.Length — остаток от деления на длину строки алфавита, чтобы получить точно значение от 0 до 32
0
1 / 1 / 0
Регистрация: 13.05.2016
Сообщений: 27
18.10.2016, 16:08  [ТС]
Спасибо, да так конечно проще, но преподаватель сказал, что нужно сделать массив
0
охотник
 Аватар для vint-81
1011 / 535 / 650
Регистрация: 29.09.2014
Сообщений: 1,083
18.10.2016, 17:41
JuriiMW,
Pascal
13
var p := (ABC.Length + ABC.IndexOf(c) + n mod ABC.Length)mod ABC.Length + 1;
Ваш вариант например при -50 не работает
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,059
19.10.2016, 04:35
vint-81, читать умеем?
Цитирую:
Цитата Сообщение от JuriiMW Посмотреть сообщение
n — смещение (если отрицательное значение, то не должно превышать размера алфавита по модулю…
0
1 / 1 / 0
Регистрация: 13.05.2016
Сообщений: 27
22.10.2016, 12:14  [ТС]
пожалуйста помогите, вот я вроде записала в массив русский алфавит , ну не знаю как быть с шифром цезаря, у меня не получается

Добавлено через 1 час 0 минут
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
const M = 33;
var b: array [0..M-1] of char; 
   n,k: integer;
   s,f:string;
   
 
Begin
  writeln ('Введите предложение');
  readln (s);
  writeln ('Чему равен сдвиг?');
  readln (n); 
  write('Шифр Цезаря -> ');
  f:='';
  b[0] := 'А';
  for var i:=1 to 32 do
    begin
      b[i] := succ(b[i-1]);
      write (b[i]);
    end;
 for var i := 1 to s.Length do
    begin
      b[i-1]:= s[i];
      k := (i + n) mod M;
    end;
  
End.
0
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
22.10.2016, 14:01
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

Попробуйте так.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
const M = 32;//без буквы Ё
var b: array [0..M-1] of char;
    n,k: integer;
    s:string;
begin
  writeln('Алфавит:');
  for var i:=0 to m-1 do
   begin
    if i=0 then b[i]:='А'
    else b[i]:=succ(b[i-1]);
    write (b[i]);
   end;
 writeln;  
 writeln ('Введите предложение прописными рускими буквами');
 readln (s);
 repeat
  write ('Чему равен сдвиг? n>0 n=');
  readln (n);
 until n>0;
writeln('Зашифрованная строка');
for var i := 1 to s.Length do
if s[i] in ['А'..'Я']then
 begin
  k:=ord(s[i])-ord('А')+n;
  if k>=M then dec(k,m); 
  s[i]:=b[k];
 end; 
writeln(s); 
writeln('Расшифрованная строка');
for var i := 1 to s.Length do
if s[i] in ['А'..'Я']then 
 begin
  k:=ord(s[i])-ord('А')-n;
  if k<0 then inc(k,m); 
  s[i]:=b[k];
 end; 
writeln(s)
end.
0
1 / 1 / 0
Регистрация: 13.05.2016
Сообщений: 27
25.10.2016, 10:28  [ТС]
я сделала как сказал преподаватель, но программа неправильно работает не знаю как исправить, он сказал что считывая элемент строки нужно найти номер этого элемента в массиве, т.е. в алфавите, но почему-то не работает
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
const
  M = 33;
 
var
  n, t, k: integer;
  s, f: string;
  d: char;
  b: array [0..M - 1] of char;
 
begin
  writeln('Введите предложение');
  readln(s);
  writeln('Чему равен сдвиг?');
  readln(n); 
  write('Шифр Цезаря -> ');
  d := 'а';
  for var i := 0 to 5 do
  begin
    b[i] := d;
    inc(d);
  end;
  b[6] := 'ё';
  d := 'ж';
  for var i := 7 to M - 1 do
  begin
    b[i] := d;
    inc(d);
  end;  
  f := '';
  for var i := 1 to s.Length do 
  begin
    t:=0;
    while (s[i] = b[t]) do t := t + 1;
  end;
  for var i := 1 to s.Length do
  begin
    k := (t + n) mod M;
    f := f + b[k];
  end;
  writeln(f);
  Writeln(b);
end.
0
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,168
25.10.2016, 11:07
Лучший ответ Сообщение было отмечено Памирыч как решение

Решение

Цитата Сообщение от K95 Посмотреть сообщение
нужно найти номер этого элемента в массиве, т.е. в алфавите,
А где это у Вас в программе?
Вот у меня в программе создается массив из 32 символов
Pascal
1
2
3
4
5
6
7
writeln('Алфавит:');
  for var i:=0 to m-1 do
   begin
    if i=0 then b[i]:='А'
    else b[i]:=succ(b[i-1]);
    write (b[i]);
   end;
С буквой Ё можно так.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
const M = 33;//с буквой Ё
var b:array[0..m-1] of char;
begin
writeln('Алфавит:');
for var i:=0 to 5 do
 begin
  if i=0 then b[i]:='А'
  else b[i]:=succ(b[i-1]);
 end;
b[6]:='Ё';
for var i:=7 to m-1 do
 begin
  if i=7 then b[i]:='Ж'
  else b[i]:=succ(b[i-1]);
 end;
for var i:=0 to m-1 do
write (b[i]);
Добавлено через 22 минуты
Попробуйте еще так.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
const  M = 33;
var  n, j, k: integer;
     s: string;
     b: array [0..M - 1] of char;
begin
  writeln('Алфавит:');
  for var i:=0 to 5 do
   begin
    if i=0 then b[i]:='А'
    else b[i]:=succ(b[i-1]);
   end;
  b[6]:='Ё';
  for var i:=7 to m-1 do
   begin
    if i=7 then b[i]:='Ж'
    else b[i]:=succ(b[i-1]);
   end;
  for var i:=0 to m-1 do
  write (b[i]);
  writeln;
  writeln ('Введите предложение прописными рускими буквами');
  readln (s);
  repeat
  write ('Чему равен сдвиг? n>0 n=');
  readln (n);
  until n>0;
  writeln('Зашифрованная строка');
for var i := 1 to s.Length do
 begin
  j:=0;//ищем номер в массиве-алфавите
  k:=-1;
  while(j<m)and(k=-1) do
  if b[j]=s[i] then k:=j
  else inc(j);
  k:=k+n;
  if k>=M then dec(k,m); 
  s[i]:=b[k];
 end; 
writeln(s); 
writeln('Расшифрованная строка');
for var i := 1 to s.Length do
 begin
  j:=0;//ищем номер в массиве-алфавите
  k:=-1;
  while(j<m)and(k=-1) do
  if b[j]=s[i] then k:=j
  else inc(j);
  k:=k-n;
  if k<0 then inc(k,m); 
  s[i]:=b[k];
 end; 
writeln(s)
end.
0
1 / 1 / 0
Регистрация: 13.05.2016
Сообщений: 27
25.10.2016, 12:14  [ТС]
спасибо огромное
0
20 / 19 / 4
Регистрация: 22.03.2018
Сообщений: 701
24.10.2018, 23:56
как сделать что бы можно было писать и маленькими буквами ?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
24.10.2018, 23:56
Помогаю со студенческими работами здесь

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

Шифр Цезаря
помогите нужно сделать прогу шифратор и дешифратор методом Цецаря

Шифр цезаря (не работает)
задача такая сделать шифр цезаря, сдвиг 10, алфавит лат строчные буквы, язык паскаль (тр7) вот накидал но комп выдает ошибку ...

задача (Шифр Цезаря)
программа автоматической расшифровки текста, большие буквы в большие маленькие в маленькие!

шифр цезаря, Шенона фано, Хаффамана
Привет всем!!!! Помогите кто может!!!! По учебе завал ничего не успеваю. Нужны исходники на шифр цезаря, Шенона фано, Хаффамана только...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru