Please subscribe to the official Codeforces channel in Telegram via the link: https://t.me/codeforces_official.
×

Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

E. Chocolate Bar

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputYou have a rectangular chocolate bar consisting of *n* × *m* single squares. You want to eat exactly *k* squares, so you may need to break the chocolate bar.

In one move you can break any single rectangular piece of chocolate in two rectangular pieces. You can break only by lines between squares: horizontally or vertically. The cost of breaking is equal to square of the break length.

For example, if you have a chocolate bar consisting of 2 × 3 unit squares then you can break it horizontally and get two 1 × 3 pieces (the cost of such breaking is 3^{2} = 9), or you can break it vertically in two ways and get two pieces: 2 × 1 and 2 × 2 (the cost of such breaking is 2^{2} = 4).

For several given values *n*, *m* and *k* find the minimum total cost of breaking. You can eat exactly *k* squares of chocolate if after all operations of breaking there is a set of rectangular pieces of chocolate with the total size equal to *k* squares. The remaining *n*·*m* - *k* squares are not necessarily form a single rectangular piece.

Input

The first line of the input contains a single integer *t* (1 ≤ *t* ≤ 40910) — the number of values *n*, *m* and *k* to process.

Each of the next *t* lines contains three integers *n*, *m* and *k* (1 ≤ *n*, *m* ≤ 30, 1 ≤ *k* ≤ *min*(*n*·*m*, 50)) — the dimensions of the chocolate bar and the number of squares you want to eat respectively.

Output

For each *n*, *m* and *k* print the minimum total cost needed to break the chocolate bar, in order to make it possible to eat exactly *k* squares.

Examples

Input

4

2 2 1

2 2 3

2 2 2

2 2 4

Output

5

5

4

0

Note

In the first query of the sample one needs to perform two breaks:

- to split 2 × 2 bar into two pieces of 2 × 1 (cost is 2
^{2}= 4), - to split the resulting 2 × 1 into two 1 × 1 pieces (cost is 1
^{2}= 1).

In the second query of the sample one wants to eat 3 unit squares. One can use exactly the same strategy as in the first query of the sample.

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/19/2018 07:27:35 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|