Задача E. Снова в космос

Автор:Жюри ROI-2011   Ограничение времени:2 сек
Входной файл:shuttle.in   Ограничение памяти:64 Мб
Выходной файл:shuttle.out  
Максимальный балл:100  

Условие

К 50-летию первого пилотируемого полета в космос решено создать новый тип космического корабля многоразового использования “Восторг”. Прямоугольная часть его корпуса (далее прямоугольник) должна быть облицована квадратными термозащитными плитками разных цветов одного и того же размера. Прямоугольник состоит из r рядов по c плиток в каждом. Плитки должны образовывать заданный рисунок.

Облицовка космического корабля отдельными плитками очень трудоемка, поэтому для выкладывания заданного рисунка используются одинаковые прямоугольные панели, состоящие из плиток. Панели крепятся на корпусе одна за другой, заполняя ряд за рядом сверху вниз. Каждый ряд панелей может быть сдвинут относительно предыдущего на одно и то же число плиток. При этом панели могут выходить за пределы прямоугольника. Панели должны быть одинаково ориентированы, то есть при параллельном переносе одной панели на место другой цвета образующих эти панели плиток должны совпадать.

Главный конструктор хочет выбрать такой размер панели a × b и сдвиг s, чтобы этими панелями можно было выложить заданный рисунок, и площадь панели была минимальна.

Требуется написать программу, которая по заданному расположению плиток в прямоугольнике рассчитывает размеры минимальной по площади панели, которую можно использовать при его облицовке, а также величину сдвига вправо (0 ≤ s < b) каждого следующего ряда относительно предыдущего.

Формат входного файла

Первая строка входного файла содержит два целых числа: r и c – размеры прямоугольника в плитках. В последующих r строках указаны цвета плиток фрагмента. Каждый из k ≤ 26 цветов обозначен одной из первых k прописных букв латинского алфавита. Гарантируется, что для этого прямоугольника можно подобрать панель размера a × b, такую, что 2 a ≤ r и 2 b ≤ c.

Формат выходного файла

В выходной файл необходимо вывести три целых числа a, b и s, удовлетворяющих условиям задачи. Если решений несколько, разрешается вывести любое из них.

Примеры тестов

Входной файл (shuttle.in) Выходной файл (shuttle.out)
1
2 4
ABAB
ABAB
1 2 0
2
5 7
DCADCAD
BABBABB
ADCADCA
BBABBAB
CADCADC
2 3 1

0.037s 0.007s 17