時間制限 : sec, メモリ制限 : KB
Japanese

マトリョーシカ

マトリョーシカはロシアの民芸品として有名な人形である. マトリョーシカは上下に分割でき,開くと中により小さい別の人形が入っている. 現れた小さい人形を開くとさらに小さい人形が入っている,というような入れ子構造になっている.


あなたは旅行先で珍しい形のマトリョーシカを見つけ,N 体の人形を購入した. i 番目の人形の形状は,xi × yi × zi の直方体である.

ひとしきりマトリョーシカを鑑賞したあなたは,マトリョーシカを仕舞おうとしている. その前に,いくつかの人形を別の人形に格納することによって必要なスペースを減らしたい. 人形を格納する際には,まだ中にひとつも人形を格納していない人形にだけ,他の人形をひとつ格納できる. ただし,直接的に格納される人形についてだけ数えるものとし,中に人形が入っている人形を別の人形に格納することはできる.

収納された人形は,外部から見えない状態になる. ただし,以下の条件を満たさなければならない.

  • 人形は回転してよいが,直方体のそれぞれの辺は,他方の直方体のいずれかの辺に平行
  • 回転後,対応する辺同士の長さそれぞれについて,収納される側の人形の長さの方が短い
  • 1 個の人形の中に直接収納できる人形の数は高々 1 個

押入れの容積は限られているので,外部から見えている人形の体積の和を最小化したい. あなたの仕事は,人形を収納する操作を任意の回数繰り返して達成できる,外部から見えている人形の体積の和の最小値を求めるプログラムを作成することである.

Input

入力は複数のデータセットからなる. データセットの個数は最大でも 50 個を超えない. 各データセットは次の形式で表される.

N
x1 y1 z1
:
:
xN yN zN

各データセットは N + 1 行からなり,データセットの 1 行目には,人形の数を表す整数 N が与えられる. 続く N 行の内 i 行目には,i 番目の人形の大きさを表す 3 つの整数 xi, yi, zi が半角スペース区切りで与えられる. これらの整数は,1 ≤ N, xi, yi, zi ≤ 100 を満たす.

入力の終わりは 1 つのゼロからなる行で表される.

Output

各データセットについて,外部から見えている人形の体積の和の最小値を 1 行で出力せよ.

Sample Input

2
1 2 3
4 2 3
3
2 5 2
3 3 4
5 5 5
5
1 1 1
2 2 2
3 3 3
4 4 4
5 5 5
5
1 1 1
2 1 1
3 1 1
4 1 1
5 1 1
10
3 1 4
1 5 9
2 6 5
3 5 8
9 7 9
3 2 3
8 4 6
2 6 4
3 3 8
3 2 7
0

Output for Sample Input

24
145
125
15
864