QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#864947 | #6842. Popcount Words | Complete_Reality | ML | 53ms | 66296kb | C++14 | 3.1kb | 2025-01-21 11:42:13 | 2025-01-21 11:42:13 |
Judging History
answer
#include<bits/stdc++.h>
#define int long long
#define pii pair<int , int>
using namespace std;
const int MAXN = 1e6 + 5;
int n , q , c[MAXN][31][2] , f[MAXN][31][2] , g[MAXN][31][2];
int ql[MAXN] , qr[MAXN];
char s[MAXN];
vector<pii> qry;
namespace AutoClicker{
int fail[MAXN] , Trie[MAXN][2] , tot = 1 , match[MAXN] , siz[MAXN];
void insert(char *s , int id) {
int p = 1 , len = strlen(s);
for (int i = 0 ; i < len ; i ++) {
int ch = s[i] - '0';
if (!Trie[p][ch]) Trie[p][ch] = ++ tot;
p = Trie[p][ch];
}
match[id] = p;
}
void bfs() {
queue<int> q;
for (int i = 0 ; i < 2 ; i ++) Trie[0][i] = 1;
q.push(1);
while(!q.empty()) {
int u = q.front();
q.pop();
for (int i = 0 ; i < 2 ; i ++) {
if (Trie[u][i]) fail[Trie[u][i]] = Trie[fail[u]][i] , q.push(Trie[u][i]);
else Trie[u][i] = Trie[fail[u]][i];
}
}
}
}
using namespace AutoClicker;
void build(int l , int r , int ql , int qr) {
if (l >= qr || r <= ql) return;
if (l >= ql && r <= qr) {
int lg = 31 - __builtin_clz(r - l);
// cerr << lg << endl;
// k * (1 << n) ~ (k + 1) * (1 << n) - 1 = 0 ~ (1 << n) - 1
qry.push_back({lg , __builtin_parity(l >> lg)});
return;
}
int mid = l + r >> 1;
build(l , mid , ql , qr) , build(mid , r , ql , qr);
}
signed main() {
ios::sync_with_stdio(false);
cin.tie(nullptr) , cout.tie(nullptr);
cin >> n >> q;
for (int i = 1 ; i <= n ; i ++) cin >> ql[i] >> qr[i] , qr[i] ++;
for (int i = 1 ; i <= q ; i ++) cin >> s , insert(s , i);
cerr << "Pre ACAM is done" << '\n';
bfs();
for (int i = 1 ; i <= tot ; i ++) f[i][0][0] = Trie[i][0] , f[i][0][1] = Trie[i][1];
cerr << "ACAM is done" << '\n';
for (int j = 1 ; j <= 29 ; j ++) {
for (int i = 1 ; i <= tot ; i ++) {
f[i][j][0] = f[f[i][j - 1][0]][j - 1][1];
f[i][j][1] = f[f[i][j - 1][1]][j - 1][0];
}
}
int pos = 1;
for (int i = 1 ; i <= n ; i ++) {
qry.clear() , build(0 , 1 << 30 , ql[i] , qr[i]); // 注意是左闭右开!
// cerr << qry.size() << '\n';
for (auto j : qry) {
// cerr << j.first << ' ' << j.second << '\n';
c[pos][j.first][j.second] ++ , pos = f[pos][j.first][j.second];
// cerr << pos << '\n';
}
}
cerr << "Build is done" << '\n';
for (int j = 29 ; j >= 0 ; j --) {
for (int i = 1 ; i <= tot ; i ++) {
g[i][j][0] += c[i][j][0] + g[i][j + 1][0];
g[i][j][1] += c[i][j][1] + g[i][j + 1][1];
g[f[i][j][1]][j][0] += g[i][j + 1][1] , g[f[i][j][0]][j][1] += g[i][j + 1][0];
// 1 Wn'Wn
// 0 WnWn'
// cerr << g[i][j][1] << ' ' << g[i][j][0] << '\n';
}
}
for (int i = 1 ; i <= tot ; i ++) {
siz[Trie[i][0]] += g[i][0][0] , siz[Trie[i][1]] += g[i][0][1];
// cerr << g[i][0][0] << ' ' << g[i][0][1] << '\n';
}
for (int i = tot ; i >= 1 ; i --) siz[fail[i]] += siz[i];
for (int i = 1 ; i <= q ; i ++) cout << siz[match[i]] << '\n';
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 16112kb
input:
3 5 2 6 1 3 4 8 0 1 11 101 0011010
output:
6 7 2 2 1
result:
ok 5 lines
Test #2:
score: 0
Accepted
time: 1ms
memory: 16112kb
input:
3 10 2 6 1 3 4 8 0 1 11 101 0011010 0 1 11 101 0011010
output:
6 7 2 2 1 6 7 2 2 1
result:
ok 10 lines
Test #3:
score: 0
Accepted
time: 53ms
memory: 66296kb
input:
100000 37701 605224571 605224571 681034454 681034463 468837041 468837048 323235128 323235135 400367345 400367345 394938241 394938241 221026001 221026007 183872918 183872926 881878131 881878138 374491962 374491967 588030380 588030381 109143398 109143401 727016146 727016149 857189138 857189138 1940312...
output:
273828 273405 99633 174195 174195 99209 16229 83404 91124 83071 83404 90791 83070 16138 3449 12780 43045 40359 43221 47903 70380 12690 12780 70624 48079 42712 40183 42887 12690 3448 413 3036 6576 6204 11678 31367 34167 6191 6484 36737 16633 31270 33957 36423 9697 2993 3036 9744 36469 34155 31543 165...
result:
ok 37701 lines
Test #4:
score: -100
Memory Limit Exceeded
input:
100000 2064 155864032 155864033 351106162 351106162 63569309 63569310 446198383 446198387 844050143 844050148 28666643 28666652 948049121 948049128 422938918 422938925 590576664 590576664 118827333 118827339 248813547 248813549 222041903 222041911 481862624 481862626 39190429 39190429 373420004 3734...
output:
4050 3660 2149 1900 1991 1669 624 1525 826 1074 1098 892 808 861 287 337 1008 517 150 675 549 525 254 844 172 720 596 212 416 445 159 128 337 0 203 804 196 321 59 91 342 333 439 110 442 83 175 79 311 533 29 143 509 211 200 396 21 191 333 83 304 141 1 1 1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 1 1 1 0 1 1...