COCI '17 Contest 6 #3 Mate

View as PDF

Submit solution

Points: 12 (partial)
Time limit: 2.0s
Memory limit: 128M

Problem type

Little Mate got an array of lowercase letters from the English alphabet as a present from his parents. In order to have at least some use of such a clever present, he decided to use it for finding rhymes when writing his next song.

To find a specific rhyme, Mate wants to select a word of length D that ends with an array of characters XY, i.e. where the next to last letter is X, and the last Y. Mate's process of selecting a word is by first crossing out some letters in a given sequence, and then merging the letters he didn't cross out into a single word. He wants to know in how many different ways he can cross out the letters so that he meets the given conditions.

The selection of two words is considered distinct if the sets of positions of the crossed-out letters are different.

Input Specification

The first line of input contains an array of lowercase letters of the English alphabet S (2 \le |S| \le 2000).

The second line of input contains the integer Q (1 \le Q \le 500\,000), the number of different rhymes for which Mate needs to select words.

Each of the following Q lines contains the integer D (2 \le D \le |S|) and an array of lowercase letters of the English alphabet XY from the task.

Output Specification

The i^\text{th} out of Q lines must contain the required number of ways for the i^\text{th} rhyme. Since that number can be quite large, output only the value modulo 1\,000\,000\,007.

Scoring

In test cases worth 40\% of total points, it will hold |S| \le 50.

In test cases worth an additional 40\% of total points, it will hold |S| \le 200.

Sample Input 1

banana
3
2 na
3 ba
4 nn

Sample Output 1

3
0
1

Explanation for Sample Output 1

Word of length 2 that ends with na can be obtained in the following ways:

b a n a n a, b a n a n a, b a n a n a.

Sample Input 2

malimateodmameitate
3
10 ot
7 aa
3 me

Sample Output 2

2
464
56

Comments

There are no comments at the moment.