QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#832216 | #6842. Popcount Words | thomas0702 | WA | 92ms | 262552kb | C++14 | 3.2kb | 2024-12-25 19:37:42 | 2024-12-25 19:37:51 |
Judging History
answer
#include<bits/stdc++.h>
#define ll long long
#define ull unsigned long long
#define lll __int128
#define db double
#define ld long double
#define eps 1e-8
#define fir first
#define sec second
#define pb push_back
using namespace std;
void rd(){}
template<typename T,typename... U> void rd(T &x,U&... arg){
x=0;int f=1,c=getchar();
while(c<'0'||c>'9'){if(c=='-') f=-1;c=getchar();}
while(c>='0'&&c<='9') x=x*10+c-48,c=getchar();
x*=f;rd(arg...);
}
void rds(char *s){
int c=getchar();
while(c<'0'||c>'1') c=getchar();
while(c>='0'&&c<='1') *s=(char)c,s++,c=getchar();
*s='\0';
}
bool Mbe;
//typedef pair<int,int> pii;
const int maxn=1e5+5,LG=30;
namespace ACAM{
const int V=2;
const char C='0';
struct Node{
int son[2],fail;
bool is[2];
vector<int> vec;
}ac[maxn*5];
int n;
void Insert(char *s,int id){
int len=(int)strlen(s+1),u=0;
// printf("s = %s, len = %d\n",s+1,len);
for(int i=1;i<=len;i++){
int &t=ac[u].son[s[i]-C];
if(!t) t=++n,ac[u].is[s[i]-C]=1;
// printf("%d --%c-> %d\n",u,s[i],t);
u=t;
}
ac[u].vec.pb(id);
}
void Get_Fail(){
queue<int> q;
for(int i=0;i<2;i++) if(ac[0].is[i]) q.push(ac[0].son[i]);
while(!q.empty()){
int u=q.front();q.pop();
for(int i=0;i<2;i++)
if(!ac[u].is[i]) ac[u].son[i]=ac[ac[u].fail].son[i];
else ac[ac[u].son[i]].fail=ac[ac[u].fail].son[i],q.push(ac[u].son[i]);
// printf("u = %d\n",u);
// printf("fail = %d, son = ",ac[u].fail);
// for(int i=0;i<2;i++) printf("%d ",ac[u].son[i]);puts("");
}
}
}//namespace ACAM
using namespace ACAM;
int N,Q,l[maxn],r[maxn],f[2][LG][maxn*5],dp[2][LG][maxn*5],a[maxn*5],in[maxn*5],ans[maxn];
char s[maxn];
bool Med;
int main(){
// fprintf(stderr,"%lf MB\n",(&Mbe-&Med)/1048576.0);
rd(N,Q);
for(int i=1;i<=N;i++) rd(l[i],r[i]);
for(int i=1;i<=Q;i++) rds(s+1),Insert(s,i);
Get_Fail();
for(int i=0;i<=n;i++) f[0][0][i]=ac[i].son[0],f[1][0][i]=ac[i].son[1];
for(int j=1;j<LG;j++)
for(int i=0;i<=n;i++)
f[0][j][i]=f[1][j-1][f[0][j-1][i]],
f[1][j][i]=f[0][j-1][f[1][j-1][i]];
map<int,int> lg;
for(int i=0;i<LG;i++) lg[1<<i]=i;
auto F=[](int n){return __builtin_popcount(n)&1;};
for(int i=1,u=0;i<=N;i++){
// printf("i = %d\n",i);
int x=l[i],y=r[i]+1;
while(x+(x&(-x))<=y){
// printf("[%d, %d), lg = %d\n",x,x+(x&(-x)),lg[x&(-x)]);
dp[F(x)][lg[x&(-x)]][u]++;
u=f[F(x)][lg[x&(-x)]][u];
x+=x&(-x);
}
for(int j=LG-1;~j;j--){
if(x+(1<<j)<=y){
// printf("[%d, %d), lg = %d\n",x,x+(1<<j),j);
dp[F(x)][j][u]++;
u=f[F(x)][j][u];
x+=(1<<j);
}
}
}
for(int j=LG-1;j;j--)
for(int i=0;i<=n;i++){
dp[0][j-1][i]+=dp[0][j][i];
dp[1][j-1][i]+=dp[1][j][i];
dp[1][j-1][f[0][j-1][i]]+=dp[0][j][i];
dp[0][j-1][f[1][j-1][i]]+=dp[1][j][i];
}
for(int i=0;i<=n;i++){
a[ac[i].son[0]]+=dp[0][0][i];
a[ac[i].son[1]]+=dp[1][0][i];
in[ac[i].fail]++;
}
queue<int> q;
for(int i=0;i<=n;i++) if(!in[i]) q.push(i);
while(!q.empty()){
int u=q.front();q.pop();
for(int i:ac[u].vec) ans[i]=a[u];
a[ac[u].fail]+=a[u];
if(!--in[ac[u].fail]) q.push(ac[u].fail);
}
for(int i=1;i<=Q;i++) printf("%d\n",ans[i]);
return 0;
}
/*
3 5
2 6
1 3
4 8
0
1
11
101
0011010
*/
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 256948kb
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: 4ms
memory: 257324kb
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: 31ms
memory: 259820kb
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: 0
Accepted
time: 92ms
memory: 261112kb
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:
274777 274799 99973 174803 174803 99996 16241 83732 91053 83750 83732 91070 83750 16246 3457 12784 43222 40510 43091 47961 70993 12757 12784 70948 47831 43239 40641 43109 12757 3489 459 2998 6565 6219 11607 31614 34345 6165 6467 36624 16421 31540 34510 36483 9693 3064 2998 9786 36657 34291 31484 163...
result:
ok 2064 lines
Test #5:
score: 0
Accepted
time: 63ms
memory: 262228kb
input:
100000 264 863548123 863548131 726674730 726674731 23567654 23567655 388640944 388640951 11253180 11253185 364951459 364951461 954258329 954258336 370336558 370336567 783663445 783663448 948622704 948622711 241717161 241717163 167305985 167305985 559579744 559579746 686340873 686340882 110381066 110...
output:
275122 274500 100192 174929 174929 99571 16458 83734 91338 83591 83734 91194 83591 15980 3543 12915 43156 40578 43255 48082 70962 12629 12915 70819 48181 43013 40479 43112 12629 3351 482 3061 6476 6439 11559 31596 34378 6200 6644 36611 16564 31518 34274 36688 9720 2909 3061 9854 36680 34139 31696 16...
result:
ok 264 lines
Test #6:
score: 0
Accepted
time: 68ms
memory: 262324kb
input:
100000 82 440580187 440580195 363746917 363746923 253327641 253327648 77285448 77285454 16654500 16654506 701949354 701949357 335798407 335798407 510898124 510898124 728200505 728200507 657089802 657089806 811878897 811878897 740279233 740279234 2002051 2002056 201584556 201584557 905281625 90528163...
output:
274946 275169 99944 175001 175001 100168 16163 83781 91017 83984 83781 91219 83984 16184 3463 12700 42944 40837 42987 48029 71306 12678 12700 71081 48072 43147 40794 43190 12678 3506 483 2980 6395 6305 11456 31487 34601 6236 6440 36547 16623 31406 34670 36636 9614 3064 2980 9720 36549 34532 31531 16...
result:
ok 82 lines
Test #7:
score: 0
Accepted
time: 67ms
memory: 262552kb
input:
100000 65 990903704 990903704 488837026 488837029 520610697 520610700 84740156 84740158 145465213 145465219 802621365 802621370 637129208 637129216 138040766 138040770 789708694 789708702 122215439 122215439 805389806 805389815 726116821 726116826 90711329 90711332 980579500 980579500 877100759 8771...
output:
275313 275152 100356 174957 174957 100194 16549 83807 90996 83960 83807 91150 83961 16233 3570 12979 43006 40801 43164 47832 71205 12755 12979 70828 47990 43159 40643 43318 12755 3478 456 3114 6506 6473 11758 31248 34498 6303 6609 36555 16430 31401 34399 36806 9714 3041 3114 9865 36500 34328 31406 1...
result:
ok 65 lines
Test #8:
score: 0
Accepted
time: 63ms
memory: 262168kb
input:
100000 15 622051406 622051410 809727709 809727711 305371768 305371773 184626015 184626015 485560137 485560143 683120615 683120618 494143101 494143106 820622384 820622384 428188273 428188280 192875194 192875198 420425386 420425394 692993018 692993020 892081956 892081958 149770059 149770067 971481390 ...
output:
274897 275773 99624 175272 175273 100500 16106 83518 91087 84185 83518 91754 84185 16315 1
result:
ok 15 lines
Test #9:
score: -100
Wrong Answer
time: 62ms
memory: 261300kb
input:
100000 37701 22481700 108517447 365920329 760528107 176789774 293610871 626946693 749768996 176851510 945414284 28086800 69412398 975208777 978832901 602518142 777697473 926108743 981817845 102894249 424879855 807095920 982351889 387442755 443766483 240971703 255490115 877218778 889992331 212556206 ...
output:
1107896626 1107896794 -1062343750 -2124726920 -2124726921 -1062343582 16684 -1062360434 -1062366547 -1062360374 -1062360435 -1062366486 -1062360374 16792 2837 13847 1616297633 1616309228 1616297706 1616303043 -1062374331 13957 13847 -1062374282 1616303116 1616297694 1616309155 1616297767 13957 2835 ...
result:
wrong answer 1st lines differ - expected: '12456513055026', found: '1107896626'