import java.io.*;
import java.util.*;
import java.math.*;
/**
* created by asheshvidyut on 04/05/18
**/
class Candies {
public static void main
(String args
[]) { try {
InputReader in
= new InputReader
(System.
in); char s[] = in.readLine().trim().toCharArray();
int freq[][] = new int[s.length][26];
for (int i = 0; i < s.length; i++) {
if (i - 1 >= 0) {
for (int j = 0; j < 26; j++) {
freq[i][j] += freq[i - 1][j];
}
}
freq[i][s[i] - 'a']++;
}
int tc = in.readInt();
for (int t = 0; t < tc; t++) {
int n = in.readInt();
int low = n;
int high = s.length;
while(low <= high) {
int mid = (low + high) >> 1;
for (int i = 0; i < s.length; i++) {
int next = i + mid - 1;
if (next < s.length && next >= 0) {
int f[] = new int[26];
for (int j = 0; j < 26; j++) {
f[j] = freq[next][j];
if (i - 1 >= 0) {
f[j] -= freq[i - 1][j];
}
}
int countLetters = 0;
Vector<Integer> odd = new Vector<>();
for (int j = 0; j < 26; j++) {
if (f[j] % 2 != 0){
odd.add(f[j]);
}
else {
countLetters += f[j];
}
}
if (odd.size() == 0 && countLetters >= n) {
ans
= Math.
min(mid, ans
); }
else {
for (int j = 0; j < odd.size() - 1; j++) {
countLetters += odd.get(j) - 1;
}
countLetters += odd.get(odd.size() - 1);
if (countLetters >= n) {
ans
= Math.
min(mid, ans
); }
}
}
}
if (ans == mid) {
high = mid - 1;
}
else {
low = mid + 1;
}
if (ans == n) {
break;
}
}
ans = -1;
out.newLine();
}
out.close();
e.printStackTrace();
}
}
}
class InputReader {
private boolean finished = false;
private byte[] buf = new byte[1024];
private int curChar;
private int numChars;
this.stream = stream;
}
public int read() {
if (numChars == -1)
throw new InputMismatchException();
if (curChar >= numChars) {
curChar = 0;
try {
numChars = stream.read(buf);
throw new InputMismatchException();
}
if (numChars <= 0)
return -1;
}
return buf[curChar++];
}
public int peek() {
if (numChars == -1)
return -1;
if (curChar >= numChars) {
curChar = 0;
try {
numChars = stream.read(buf);
return -1;
}
if (numChars <= 0)
return -1;
}
return buf[curChar];
}
public int readInt() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
int res = 0;
do {
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
} while (!isSpaceChar(c));
return res * sgn;
}
public long readLong() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
long res = 0;
do {
if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
} while (!isSpaceChar(c));
return res * sgn;
}
int length = readInt();
if (length < 0)
return null;
byte[] bytes = new byte[length];
for (int i = 0; i < length; i++)
bytes[i] = (byte) read();
try {
return new String(bytes,
"UTF-8"); }
}
public static boolean isSpaceChar(int c) {
return c == ' ' || c == '\n' || c == '\r' || c == '\t' || c == -1;
}
int c = read();
while (c != '\n' && c != -1) {
if (c != '\r')
buf.appendCodePoint(c);
c = read();
}
return buf.toString();
}
while (s.trim().length() == 0)
s = readLine0();
return s;
}
public String readLine
(boolean ignoreEmptyLines
) { if (ignoreEmptyLines)
return readLine();
else
return readLine0();
}
try {
throw new InputMismatchException();
}
}
public char readCharacter() {
int c = read();
while (isSpaceChar(c))
c = read();
return (char) c;
}
public double readDouble() {
int c = read();
while (isSpaceChar(c))
c = read();
int sgn = 1;
if (c == '-') {
sgn = -1;
c = read();
}
double res = 0;
while (!isSpaceChar(c) && c != '.') {
if (c == 'e' || c == 'E')
return res
* Math.
pow(10, readInt
()); if (c < '0' || c > '9')
throw new InputMismatchException();
res *= 10;
res += c - '0';
c = read();
}
if (c == '.') {
c = read();
double m = 1;
while (!isSpaceChar(c)) {
if (c == 'e' || c == 'E')
return res
* Math.
pow(10, readInt
()); if (c < '0' || c > '9')
throw new InputMismatchException();
m /= 10;
res += (c - '0') * m;
c = read();
}
}
return res * sgn;
}
public boolean isExhausted() {
int value;
while (isSpaceChar(value = peek()) && value != -1)
read();
return value == -1;
}
return readString();
}
public boolean readBoolean() {
return readInt() == 1;
}
}