QOJ.ac

QOJ

Time Limit: 1 s Memory Limit: 32 MB Total points: 10

#11039. Cliquers Strike Back [A]

统计

An undirected graph is called a labeled cliquer if each connected component of the graph is a clique and the vertices of the graph are numbered with numbers from the set $\{1, \ldots, n\}$. Maurycy has drawn all labeled cliquers with $ n $ vertices on a piece of paper and is going to assess beauty of each of them with a number from the set $\{1, \ldots, m\}$ (in particular, different cliquers may be assigned equal grades). In how many ways can he do this? The result should be computed modulo $10^{9} - 401$. The figure below depicts all labeled cliquers for $ n = 3$.

problem_11039_1.gif

Input Format

The only line of the standard input contains two integers $ n $ and $ m $ ($1 ≤ n, m ≤ 10^{18}$), separated by a single space and denoting the number of vertices of each labeled cliquer and the number of grades respectively.

Output Format

The only line of the standard output should contain the number of possible sets of grades modulo $10^{9} - 401$.

Example

Input

3 2

Output

32