#include #include using namespace std; int op(int x, int y){ return max(x, y); } int e(){ return 0; } int main(){ int N, Q; cin >> N >> Q; string S; cin >> S; vector sum(N + 1); sum[0] = 0; for (int i = 0; i < N; i++){ if (S[i] == '0'){ sum[i + 1] = sum[i] + 1; } else { sum[i + 1] = sum[i] - 1; } } set st; st.insert(0); st.insert(N); for (int i = 1; i < N; i++){ if (S[i] != S[i - 1]){ st.insert(i); } } vector c(N, 1); for (int i = 1; i < N; i++){ if (S[i] == S[i - 1]){ c[i] = c[i - 1] + 1; } else { c[i] = 1; } } atcoder::segtree ST(c); for (int i = 0; i < Q; i++){ int L, R, K; cin >> L >> R >> K; L--; auto itr = st.lower_bound(L); bool ok = false; if (*itr >= R){ if (R - L >= K){ ok = true; } } else { if (*itr - L >= K){ ok = true; } if (ST.prod(*itr, R) >= K){ ok = true; } } if (!ok){ cout << R - L << endl; } else { int s = sum[R] - sum[L]; s %= K * 2 - 1; s += K * 2 - 1; s %= K * 2 - 1; s = min(s, K * 2 - 1 - s); cout << K * 2 - 2 - s << endl; } } }