結果
問題 |
No.3244 Range Multiple of 8 Query
|
ユーザー |
|
提出日時 | 2025-08-22 22:08:09 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,215 bytes |
コンパイル時間 | 2,156 ms |
コンパイル使用メモリ | 206,904 KB |
実行使用メモリ | 7,720 KB |
最終ジャッジ日時 | 2025-08-22 22:08:23 |
合計ジャッジ時間 | 13,562 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 10 WA * 13 TLE * 1 -- * 16 |
ソースコード
#include <bits/stdc++.h> using namespace std; using ll = long long; int main(){ ios::sync_with_stdio(false); cin.tie(0); int n, q; string s; cin >> n >> q >> s; vector<tuple<int,int,int>> ls; vector<vector<int>> pos(10); for(int i = 0; i < n; i++) pos[s[i] - '0'].emplace_back(i); for(int i = 0; i < 1000; i += 8){ ls.emplace_back(i / 100, i / 10 % 10, i % 10); auto [a, b, c] = ls.back(); } auto get = [&](int d, int r){ int p = lower_bound(pos[d].begin(), pos[d].end(), r) - pos[d].begin(); p--; if(p == -1) return -1; return pos[d][p]; }; auto f = [&](int l, int r){ // l以上 r 未満で最も大きいもの int ans = 1 << 30; if(r - l >= 2){ for(auto [c2, c1, c0] : ls){ if(r - l >= 3){ int p0 = get(c0, r); if(p0 < l) continue; int p1 = get(c1, r); if(p1 == p0) p1 = get(c1, p1); if(p1 < l) continue; int p2 = get(c2, r); if(p2 == p0) p2 = get(c2, p2); if(p2 == p1) p2 = get(c2, p2); if(p0 < p1) p1--; if(p0 < p2) p2--; if(p1 < p2) p2--; int d = r - 1 - p0; d += r - 2 - p1; d += r - 3 - p2; ans = min(ans, d); }else if(r - l == 2){ if(c2 != 0) break; int p0 = get(c0, r); if(p0 < l) continue; int p1 = get(c1, r); if(p1 == p0) p1 = get(c1, p1); if(p1 < l) continue; if(p0 < p1) p1--; int d = r - 1 - p0; d += r - 2 - p1; ans = min(ans, d); } } }else{ int v = s[l] - '0'; if(v % 8 == 0) return 0; } if(ans >> 30) ans = -1; return ans; }; while(q--){ int l, r; cin >> l >> r; l--; cout << f(l, r) << '\n'; } }