Building Cubes with AtCoDeer

AtCoder
IDarc062_c
Time4000ms
Memory256MB
Difficulty
AtCoDeer the deer has $N$ square tiles. The tiles are numbered $1$ through $N$, and the number given to each tile is written on one side of the tile. Also, each corner of each tile is painted in one of the $1000$ colors, which are represented by the integers $0$ between $999$. The top-left, top-right, bottom-right and bottom-left corner of the tile with the number $i$ are painted in color $C_{i,0}, C_{i,1}, C_{i,2}$ and $C_{i,3}$, respectively, when seen in the direction of the number written on the tile (See Figure $1$). ![image](https://atcoder.jp/img/arc062/b8ec940254d280135500dab6d00d4370.png)Figure $1$: The correspondence between the colors of a tile and the input AtCoDeer is constructing a cube using six of these tiles, under the following conditions: * For each tile, the side with the number must face outward. * For each vertex of the cube, the three corners of the tiles that forms it must all be painted in the same color. Help him by finding the number of the different cubes that can be constructed under the conditions. Since each tile has a number written on it, two cubes are considered different if the set of the used tiles are different, or the tiles are used in different directions, even if the formation of the colors are the same. (Each tile can be used in one of the four directions, obtained by $90°$ rotations.) Two cubes are considered the same only if rotating one in the three dimensional space can obtain an exact copy of the other, including the directions of the tiles. ![image](https://atcoder.jp/img/arc062/8c7552f20698dab0aad52bba476fe6d7.png)Figure $2$: The four directions of a tile ## Constraints * $6≦N≦400$ * $0≦C_{i,j}≦999 (1≦i≦N , 0≦j≦3)$ ## Input The input is given from Standard Input in the following format: $N$ $C_{1,0}$ $C_{1,1}$ $C_{1,2}$ $C_{1,3}$ $C_{2,0}$ $C_{2,1}$ $C_{2,2}$ $C_{2,3}$ $:$ $C_{N,0}$ $C_{N,1}$ $C_{N,2}$ $C_{N,3}$ [samples]
Samples
Input #1
6
0 1 2 3
0 4 6 1
1 6 7 2
2 7 5 3
6 4 5 7
4 0 3 5
Output #1
1

The cube below can be constructed.
![image](https://atcoder.jp/img/arc062/094fbca5395bfaaea28c98c51230693b.png)
Input #2
8
0 0 0 0
0 0 1 1
0 1 0 1
0 1 1 0
1 0 0 1
1 0 1 0
1 1 0 0
1 1 1 1
Output #2
144
Input #3
6
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
Output #3
122880
API Response (JSON)
{
  "problem": {
    "name": "Building Cubes with AtCoDeer",
    "description": {
      "content": "AtCoDeer the deer has $N$ square tiles. The tiles are numbered $1$ through $N$, and the number given to each tile is written on one side of the tile. Also, each corner of each tile is painted in one o",
      "description_type": "Markdown"
    },
    "platform": "AtCoder",
    "limit": {
      "time_limit": 4000,
      "memory_limit": 262144
    },
    "difficulty": "None",
    "is_remote": true,
    "is_sync": true,
    "sync_url": null,
    "sign": "arc062_c"
  },
  "statements": [
    {
      "statement_type": "Markdown",
      "content": "AtCoDeer the deer has $N$ square tiles. The tiles are numbered $1$ through $N$, and the number given to each tile is written on one side of the tile. Also, each corner of each tile is painted in one o...",
      "is_translate": false,
      "language": "English"
    }
  ]
}
Full JSON Raw Segments