Rubik’s Cube Coloring (hard version) solution Codeforces

Rubik’s Cube Coloring (hard version) solution Codeforces

It is the hard version of the problem. The difference is that in this version, there are nodes with already chosen colors.

Theofanis is starving, and he wants to eat his favorite food, sheftalia. However, he should first finish his homework. Can you help him with this problem?

You have a perfect binary tree of 2𝑘12k−1 nodes — a binary tree where all vertices 𝑖i from 11 to 2𝑘112k−1−1 have exactly two children: vertices 2𝑖2i and 2𝑖+12i+1. Vertices from 2𝑘12k−1 to 2𝑘12k−1 don’t have any children. You want to color its vertices with the 66 Rubik’s cube colors (White, Green, Red, Blue, Orange and Yellow).

Rubik’s Cube Coloring (hard version) solution Codeforces

Let’s call a coloring good when all edges connect nodes with colors that are neighboring sides in the Rubik’s cube.

Rubik's Cube Coloring (hard version) solution Codeforces

A picture of Rubik’s cube and its 2D map.

More formally:

  • a white node can not be neighboring with white and yellow nodes;
  • a yellow node can not be neighboring with white and yellow nodes;
  • a green node can not be neighboring with green and blue nodes;
  • a blue node can not be neighboring with green and blue nodes;
  • a red node can not be neighboring with red and orange nodes;
  • an orange node can not be neighboring with red and orange nodes;

Rubik’s Cube Coloring (hard version) solution Codeforces

However, there are 𝑛n special nodes in the tree, colors of which are already chosen.

You want to calculate the number of the good colorings of the binary tree. Two colorings are considered different if at least one node is colored with a different color.

The answer may be too large, so output the answer modulo 109+7109+7.

Rubik’s Cube Coloring (hard version) solution Codeforces

Input

The first line contains the integers 𝑘k (1𝑘601≤k≤60) — the number of levels in the perfect binary tree you need to color.

The second line contains the integer 𝑛n (1𝑛min(2𝑘1,2000)1≤n≤min(2k−1,2000)) — the number of nodes, colors of which are already chosen.

The next 𝑛n lines contains integer 𝑣v (1𝑣2𝑘11≤v≤2k−1) and string 𝑠s — the index of the node and the color of the node (𝑠s is one of the white, yellow, green, blue, red and orange).

It is guaranteed that each node 𝑣v appears in the input at most once.

Output

Print one integer — the number of the different colorings modulo 109+7109+7.

Rubik’s Cube Coloring (hard version) solution Codeforces

Examples

input

Copy
3
2
5 orange
2 white
output

Copy
1024

Rubik’s Cube Coloring (hard version) solution Codeforces

input

Copy
2
2
1 white
2 white
output

Copy
0

Rubik’s Cube Coloring (hard version) solution Codeforces

input

Copy
10
3
1 blue
4 red
5 orange
output

Copy
328925088
Note

In the picture below, you can see one of the correct colorings of the first test example.

Rubik's Cube Coloring (hard version) solution Codeforces

Leave a Reply

Your email address will not be published. Required fields are marked *

*