PLCNMGME - Place-name game

no tags 

Place-name game is a favourite pastime among the few children that go to school in Dystopia. The game is played as follows : One player says the name of a city and the next player has to say the name of a city that begins with the last letter of the said city. The game then goes on.

Dystopian cities recently went through a massive renaming. Now each city has a name that begins with a consonant and ends with a consonant.

Anaximander is a student with a very poor knowledge of geography. Hence he fares very poorly in the game. He has recently come up with a new idea. He would just remember the name of 21 Dystopian cities. He wants to choose the 21 cities such that there is exactly one city name starting with each consonant and exactly one city name ending with each. This would give him a good advantage in the game, whether he is playing first or second.

Given the names of the N cities in Dystopia, find out the number of ways Anaximander can select 21 city names out of the lot satisfying the properties. As this number can be very large, output it modulo 100000007.

Input

The first line of the input contains N (≤1000), the number of cities. This is followed by N lines, each containing the name of a city in Dystopia. Each city name will begin and end with a consonant, and will contain at least 2 and at most 10 letters.

Output

Output modulo 100000007 the number of ways Anaximander can choose 21 city names out of the N with the intended properties.

Example

Input:
23
BBBB
CCCC
DDDD
FFFF
GGGG
HHHH
JJJJ
KKKK
LLLL
MMMM
NNNN
PPPP
QQQQ
RRRR
SSSS
TTTT
VVVV
WWWW
XXXX
YYYY
ZZZZ
BAAC
CAAB

Output:
2

hide comments
Adrian Beker: 2013-07-15 15:03:20

I got TLE with long long. When I changed it to int, I got AC. In my opinion, long long is still needed for a small number of test cases when the result of a multiplication can overflow the int data type.

Radhakrishnan Venkataramani: 2012-06-15 18:48:33

Recursion gets TLE. Iteration gets AC :)

Dominik Kempa: 2011-02-14 18:29:14

Note that you have to print the result modulo 100000007 which is NOT 10^9+7.


Added by:Raziman T V
Date:2011-02-13
Time limit:1s
Source limit:50000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Languages:All except: ASM64
Resource:IOPC2011