//Let's join Kaede Takagaki Fan Club !! #include #include #include using namespace std; typedef long long ll; typedef pair P; typedef pair P1; typedef pair P2; #define pu push #define pb push_back #define mp make_pair #define eps 1e-7 #define INF 1000000000 #define fi first #define sc second #define rep(i,x) for(int i=0;i void dmp(T a){ rep(i,a.size()) cout << a[i] << " "; cout << endl; } template bool chmax(T&a, T b){ if(a < b){ a = b; return 1; } return 0; } template bool chmin(T&a, T b){ if(a > b){ a = b; return 1; } return 0; } template void g(T &a){ cin >> a; } template void o(const T &a,bool space=false){ cout << a << (space?' ':'\n'); } //ios::sync_with_stdio(false); const ll mod = 1000000007;//998244353 template void add(T&a,T b){ a+=b; if(a >= mod) a-=mod; } int NN,k; int ran[400005]; int tmp[400005]; int sa[400005]; bool compare_sa(int i,int j) { if(ran[i] != ran[j]) return ran[i] < ran[j]; else { int ri = i+k<=NN ? ran[i+k]: -1; int rj = j+k<=NN ? ran[j+k]: -1; return ri < rj; } } void construct_sa(string S) { NN = S.size(); for(int i=0;i<=NN;i++) { sa[i] = i; ran[i] = i> n >> m >> q; cin >> s; s = reduce(s); m *= n/s.size(); n = s.size(); //cout << n << " " << m << endl; if(m > 4){ int n = s.size(); s = s+s+s+s; construct_sa(s); construct_lcp(s); ll cur = 0; rep(i,100005) ans2[i] = -1; mapM; vector>vec; for(int i=1;i<=4*n;i++){ //cout << sa[i]%n << " " << (sa[i] < 3*n?1:0) << endl; if(sa[i] >= 3*n){ M[++cur] = sa[i]%n; } else if(ans2[sa[i]%n] == -1){ //answer for n*(m-2)+sa[i]%n ans2[sa[i]%n] = 1; vec.pb(mp(++cur, sa[i]%n)); cur += (m-2); } } rep(i,q) { ll a; g(a); if(M.find(a) != M.end()){ o(1LL*(m-1)*n + M[a] + 1, (i==q-1?0:1)); } else{ int x = POSL(vec, mp(a, INF)); x--; assert(vec[x].fi <= a && a <= vec[x].fi+m-2); int id = vec[x].sc; o(1LL*(m-2)*n+id - 1LL*n*(a-vec[x].fi) + 1, (i==q-1?0:1)); } } } else{ string t = ""; rep(i,m) t += s; construct_sa(t); construct_lcp(t); rep(i,q) { int a; g(a); o(1+sa[a], (i==q-1?0:1)); } } }