結果
| 問題 |
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';
}
}