printРабочее место участника

printЗадачи

222. Симпатичные узоры

Ограничения: время – 3s/6s, память – 32MiB Ввод: input.txt или стандартный ввод Вывод: output.txt или стандартный вывод copy
Послать решение Blockly Посылки Темы Где Обсудить (0)

Компания BrokenTiles планирует заняться выкладыванием во дворах у состоятельных клиентов узор из черных и белых плиток, каждая из которых имеет размер 1x1 метр. Известно, что дворы всех состоятельных людей имеют наиболее модную на сегодня форму прямоугольника `M` x `N` метров.
Однако при составлении финансового плана у директора этой организации появилось целых две серьезных проблемы: во первых, каждый новый клиент очевидно захочет, чтобы узор, выложенный у него во дворе, отличался от узоров всех остальных клиентов этой фирмы, а во вторых, этот узор должен быть симпатичным.
Как показало исследование, узор является симпатичным, если в нем нигде не встречается квадрата 2x2 метра, полностью покрытого плитками одного цвета.
Для составления финансового плана директору необходимо узнать, сколько клиентов он сможет обслужить, прежде чем симпатичные узоры данного размера закончатся. Помогите ему!
На первой строке входного файла находятся два положительных целых числа, разделенные пробелом, `M` и `N\ (1\ ≤\ M⋅N\ ≤\ 30)`.
Выведите в выходной файл единственное число – количество различных симпатичных узоров, которые можно выложить во дворе размера `M` x `N`. Узоры, получающиеся друг из друга сдвигом, поворотом или отражением считаются различными.

Пример ввода 1

3 3

Пример вывода 1

322

Пример ввода 2

2 2

Пример вывода 2

14
Источник: http://neerc.ifmo.ru/school/archive/
loading