eolymp
bolt
Попробуйте наш новый интерфейс для отправки задач
Задачи

Симпатичные узоры - 3

Симпатичные узоры - 3

Компания \textit{BrokenTiles} планирует заняться выкладыванием во дворах у состоятельных клиентов узор из черных и белых плиток, каждая из которых имеет размер \textbf{1}×\textbf{1} метр. Известно, что дворы всех состоятельных людей имеют наиболее модную на сегодня форму прямоугольника \textbf{n}×\textbf{m} метров. Однако при составлении финансового плана у директора этой организации появилось целых две серьезных проблемы: во первых, каждый новый клиент очевидно захочет, чтобы узор, выложенный у него во дворе, отличался от узоров всех остальных клиентов этой фирмы, а во вторых, этот узор должен быть симпатичным. Как показало исследование, узор является симпатичным, если в нем нигде не встречается квадрата \textbf{2}×\textbf{2} метра, полностью покрытого плитками одного цвета. Для составления финансового плана директору необходимо узнать, сколько клиентов он сможет обслужить, прежде чем симпатичные узоры данного размера закончатся. Помогите ему! \InputFile На первой строке входного файла находятся три натуральных числа \textbf{n}, \textbf{m} и \textbf{p} (\textbf{1} ≤ \textbf{n} ≤ \textbf{10^100}, \textbf{1} ≤ \textbf{m} ≤ \textbf{5}, \textbf{1}≤ \textbf{p} ≤ \textbf{10000}). \OutputFile Выведите в выходной файл единственное число --- количество различных симпатичных узоров, которые можно выложить во дворе размера \textbf{n}×\textbf{m} по модулю \textbf{p}. Узоры, получающиеся друг из друга сдвигом, поворотом или отражением считаются различными.
Лимит времени 1 секунда
Лимит использования памяти 64 MiB
Входные данные #1
2 2 20
Выходные данные #1
14