Задача №111486. Палиндромность

Напомним, что палиндромом называется строка, которая читается одинаково как слева направо, так и справа налево. Например, палиндромами являются строки “abba” и “madam”.

Для произвольной строки \(s\) введем операцию деления пополам, обозначаемую \(half(s)\). Значение \(half(s)\) определяется следующими правилами:

Если \(s\) не является палиндромом, то значение \(half(s)\) не определено;

Если \(s\) имеет длину 1, то значение \(half(s)\) также не определено;

Если \(s\) является палиндромом четной длины \(2m\), то \(half(s)\) — это строка, состоящая из первых \(m\) символов строки \(s\);

Если \(s\) является палиндромом нечетной длины \(2m+1\), большей \(1\), то \(half(s)\) — это строка, состоящая из первых \(m + 1\) символов строки \(s\).

Например, значения \(half(\mbox{inforamatics})\) и \(half(\mbox{i})\) не определены, \(half(\mbox{abba}) = \mbox{ab}\), \(half(\mbox{madam}) = \mbox{mad}\).

Палиндромностью строки \(s\) будем называть максимальное число раз, которое можно применить к строке \(s\) операцию деления пополам, чтобы результат был определен.

Например, палиндромность строк “informatics” и “i” равна 0, так как к ним нельзя применить операцию деления пополам даже один раз. Палиндромность строк “abba” и “madam” равна 1, а палиндромность строки “totottotot” равна 3, поскольку операция деления пополам применима к ней три раза: “totottotot” → “totot” → “tot” → “to”.

Рассмотрим все строки длины \(n\), состоящие из строчных латинских букв, палиндромность которых равна \(p\). Ваша задача — найти \(k\)-ю в алфавитном порядке среди этих строк.

Входные данные

В первой строке входного файла содержатся три целых числа \(n\), \(p\) и \(k\) — длина и палиндромность строк рассматриваемого множества и номер искомой строки в этом множестве (\(1 \le n \le 200\); \(0 \le p \le 8\); \(1 \le k \le 10^9\)).

Гарантируется, что в множестве строк длины \(n\) с палиндромностью \(p\) содержится не менее \(k\) элементов, то есть искомая строка существует.

Выходные данные

В выходной файл выведите \(k\)-ю в алфавитном порядке строку из множества строк длины \(n\) с палиндромностью \(p\).

Примеры
Входные данные
4 1 1
Выходные данные
abba
Входные данные
10 3 490
Выходные данные
totottotot
Входные данные
5 0 6597777
Выходные данные
olymp
Сдать: для сдачи задач необходимо войти в систему