Polygon Division

Time Limit: 2000ms
Memory Limit: 131072KB
This problem will be judged on PKU. Original ID: 3597
64-bit integer IO format: %lld      Java class name: Main

Description

Given a regular polygon, there are numerous ways to divide it into several triangles and/or quadrangles by adding some diagonals that do not properly intersect each other. For example, Figure 4 shows all ten different divisions of a regular pentagon into triangles and quadrangles.

Figure 4: Divisions of a regular pentagon into triangles and quadrangles

Given n, the number of sides of the polygon, compute the number of such divisions.

Input

The input contains multiple test cases. Each test case consists of a single integer n (3 ≤ n ≤ 5000) on a separate line. The input ends where EOF is met.

Output

For each test case, print the answer modulo 264 on a separate line.

Sample Input

3
4
5
6
7
8
9
10

Sample Output

1
3
10
38
154
654
2871
12925

Source

Language: 
Theme: 
Share Code? 

Powered by NB231 | Current Style: .