Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

data structures

hashing

string suffix structures

strings

*2300

No tag edit access

The problem statement has recently been changed. View the changes.

×
E. Games on a CD

time limit per test

4 secondsmemory limit per test

512 megabytesinput

standard inputoutput

standard outputSeveral years ago Tolya had *n* computer games and at some point of time he decided to burn them to CD. After that he wrote down the names of the games one after another in a circle on the CD in clockwise order. The names were distinct, the length of each name was equal to *k*. The names didn't overlap.

Thus, there is a cyclic string of length *n*·*k* written on the CD.

Several years have passed and now Tolya can't remember which games he burned to his CD. He knows that there were *g* popular games that days. All of the games he burned were among these *g* games, and no game was burned more than once.

You have to restore any valid list of games Tolya could burn to the CD several years ago.

Input

The first line of the input contains two positive integers *n* and *k* (1 ≤ *n* ≤ 10^{5}, 1 ≤ *k* ≤ 10^{5}) — the amount of games Tolya burned to the CD, and the length of each of the names.

The second line of the input contains one string consisting of lowercase English letters — the string Tolya wrote on the CD, split in arbitrary place. The length of the string is *n*·*k*. It is guaranteed that the length is not greater than 10^{6}.

The third line of the input contains one positive integer *g* (*n* ≤ *g* ≤ 10^{5}) — the amount of popular games that could be written on the CD. It is guaranteed that the total length of names of all popular games is not greater than 2·10^{6}.

Each of the next *g* lines contains a single string — the name of some popular game. Each name consists of lowercase English letters and has length *k*. It is guaranteed that the names are distinct.

Output

If there is no answer, print "NO" (without quotes).

Otherwise, print two lines. In the first line print "YES" (without quotes). In the second line, print *n* integers — the games which names were written on the CD. You should print games in the order they could have been written on the CD, it means, in clockwise order. You can print games starting from any position. Remember, that no game was burned to the CD more than once. If there are several possible answers, print any of them.

Examples

Input

3 1

abc

4

b

a

c

d

Output

YES

2 1 3

Input

4 2

aabbccdd

4

dd

ab

bc

cd

Output

NO

Codeforces (c) Copyright 2010-2024 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Feb/25/2024 17:29:06 (l3).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|