Исполнитель "шифровщик" умеет выполнять команды: менять(i,j) — меняет буквы i-ю и j-ю местами, например, если задано слово кот и команда менять(1,3), результатом ее выполнения будет слово ток; сдвигать — сдвигает буквы слова вправо по кругу на один символ (последний символ попадает в 1-й), например, если задано слово ток и команда сдвигать, результатом ее выполнения будет кто; а также проверять условия еслигласный(i) еслисогласный(i) — исполнитель проверяет i-й символ и если условие выполнено, то продолжает выполнять следующую команду в строке, если нет — переходит на следующую строку программы; продолжение выполнения может быть задано командой: повторятьс(n) — повторяет выполнение команд, начиная со строки n. во избежание путаницы все строки программы пронумерованы. шифровщик выполнил программу: 1: менять(1,3) 2: менять(2,5) 3: менять(4,7) 4: менять(6,8) 5: еслигласный(1) еслигласный(8) сдвигать повторятьс(1) 6: еслисогласный(1) еслисогласный(8) сдвигать повторятьс(1) получилось слово анацимпр – какое слово было исходным?
// PascalABC.Net 3.0, сборка 1066
procedure CheckString(var s:string; var n:integer);
var
i:integer;
begin
i:=Length(s);
while i>0 do begin
if not(s[i] in ['a'..'z']) then Delete(s,i,1);
Dec(i)
end;
n:=Length(s)
end;
var
s1,s2:string;
i,p,n1,n2:integer;
begin
Write('Введите первую строку: '); Readln(s1);
CheckString(s1,n1);
if n1=0 then Writeln('Введенная строка не содержит допустимых символов')
else begin
Write('Введите вторую строку: '); Readln(s2);
CheckString(s2,n2);
if n2=0 then Writeln('Введенная строка не содержит допустимых символов')
else
{ теперь обе строки содержат только маленькие латинские буквы }
if n1=n2 then begin
for i:=1 to n1 do begin
p:=Pos(s1[i],s2);
if p=0 then Break
else Delete(s2,p,1)
end;
if Length(s2)=0 then Writeln('Решение имеется')
else Writeln('Решения нет')
end
else
Writeln('Решения нет');
end
end.
Тестовое решение:
Введите первую строку: this is my own deal!
Введите вторую строку: Тест: *is now=l2ead my sthi?
Решение имеется
Также имеется современное решение, которому пока что в школах не учат:
// PascalABC.Net 3.0, сборка 1066
begin
var s1:=ReadString('Введите первую строку: ').Where(x->x in ['a'..'z']);
if s1.Count=0 then
Writeln('Введенная строка не содержит допустимых символов')
else begin
var s2:=ReadString('Введите вторую строку: ').Where(x->x in ['a'..'z']);
if s2.Count=0 then
Writeln('Введенная строка не содержит допустимых символов')
else
if s1.Except(s2).Count>0 then Writeln('Решения нет')
else Writeln('Решение имеется')
end
end.
12
Объяснение:
На экране число 3
Рассмотрим программу 21212 последовательно, записывая результаты каждого шага через b.
Результат первого шага вычисляется в числовом значении сразу же 3 * 3 = 9, значит далее рассматриваем начиная со 2 шага.
2) 9 + b
3) (9 + b) * 3
4) (9 + b) * 3 + b
5) ((9 + b) * 3 + b) * 3
За 5 шагов по условию мы получаем результат 225, приравняем выражение результата 5 шага к 225 и решим уравнение:
225 = ((9 + b) * 3 + b) * 3
75 = (9 + b) * 3 + b
75 = 27 + 3b + b
75 = 27 + 4b
4b = 48
b = 12
Получили ответ, b=12