Условие: Ключом шифра, называемого «решёткой», является квадратный трафарет размера 66 клеток. В трафарете
вырезаны 9 клеток так, что при наложении его на квадратный лист бумаги размера 66 клеток четырьмя возможными его вырезы полностью покрывают всю площадь листа. Буквы сообщения (без пропусков) последовательно
вписываются в вырезы трафарета (по строкам, в каждой строке слева направо) при каждом из четырех его возможных
положений. Прочтите исходный текст, если после шифрования на листе бумаги оказался следующий текст (на русском
языке):
И В Б Р Н М
Е А И - Р И
Л Н - Е А Н
В - А С О -
- Я Ь Т О Ц
И С А - Ш О
Необходимо расшифровать сообщение и найти ключ, то есть местоположение всех прорезей в решётке.
ответ запишите прописными буквами, разделяя слова пробелами.
begin
var a:=ReadLines('m17.txt').JoinIntoString.ToIntegers;
a.Println;
var b:=a.Select((x,i)->Rec(x,i)).Where(x->x.Item1<0)
.Select(x->x.Item2).ToArray;
if b.Count<>2 then
Writeln('Количество отрицательных элементов не равно двум')
else begin
a:=SeqFill(b[0],0).Concat(a.Skip(b[0]).Take(b[1]-b[0]+1))
.Concat(SeqFill(a.Length-b[1]-1,0)).ToArray;
a.Println
end
end.
Тестовое решение:
23 14 7 15 0 13 -6 41 18 13 8 42 27 -11 3 19 10
0 0 0 0 0 0 -6 41 18 13 8 42 27 -11 0 0 0
Файл с исходными данными имеет имя m17.txt. Тестовый файл находится во вложении. Разбивка на строки сделана по 5 значений, но может быть совершенно произвольной. Также нет привязки именно к 17 числам, главное - чтобы отрицательных чисел было ровно два, иначе будет выдано сообщение о их неверном количестве.