QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#277968 | #7518. GCD of Pattern Matching | ship2077 | WA | 1ms | 3944kb | C++14 | 1.1kb | 2023-12-07 09:59:11 | 2023-12-07 09:59:11 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
const int ans[]={0,0,2,1,3,2,5,3,7,4,9,5,11,6,13,7,15};
mt19937 mt(time(NULL));
constexpr int M=30;char s[M];
int n,d,num,T,f[M],vec[M];
unsigned long long sum,gcd,g[M],pw[M];
int read(){
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)) {if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)) x=x*10+ch-48,ch=getchar();
return x*f;
}
int main(){
scanf("%d",&T); while (T--){
scanf("%d%s",&d,s+1);n=strlen(s+1);
for (int i=pw[0]=1;i<=n;i++) pw[i]=pw[i-1]*d;
for (int i=0;i<26;i++) g[i]=0; iota(f,f+d,0);
for (int i=1;i<=n;i++) g[s[i]-'a']+=pw[n-i]; num=0;
for (int i=0;i<26;i++)
if (g[i]) vec[num++]=i;
if (num==d) {printf("%d\n",ans[d]);continue;}
if (num>d) {puts("0");continue;}
int t=num>=10?80:num>=5?70:60;gcd=0;
while (t--){ sum=0;bool fl=1;
for (int i=0;i<num;i++){
sum+=f[i]*g[vec[i]];
if (!f[i]&&vec[i]==s[1]-'a')
{fl=0;break;}
}
if (fl) gcd=__gcd(gcd,sum);
shuffle(f,f+d,mt);
if (gcd==1) break;
}
printf("%llu\n",gcd);
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 1ms
memory: 3944kb
input:
5 10 ccpcccpc 10 cpcpcp 10 cpc 4 cpccpc 4 dhcp
output:
10001 10101 1 65 3
result:
ok 5 number(s): "10001 10101 1 65 3"
Test #2:
score: 0
Accepted
time: 0ms
memory: 3704kb
input:
30 2 ab 3 abc 4 abcd 5 abcde 6 abcdef 7 abcdefg 8 abcdefgh 9 abcdefghi 10 abcdefghij 11 abcdefghijk 12 abcdefghijkl 13 abcdefghijklm 14 abcdefghijklmn 15 abcdefghijklmno 16 abcdefghijklmnop 16 a 16 ab 16 abc 16 abcd 16 abcde 16 abcdef 16 abcdefg 16 abcdefgh 16 abcdefghi 16 abcdefghij 16 abcdefghijk ...
output:
2 1 3 2 5 3 7 4 9 5 11 6 13 7 15 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
result:
ok 30 numbers
Test #3:
score: -100
Wrong Answer
time: 0ms
memory: 3700kb
input:
12 10 abccbaabc 10 abcdeedcba 10 abccbaabccba 3 abccbaabccba 4 abcddcba 4 abcddcbaabcddcba 5 online 5 onlie 6 online 3 ccc 10 ccc 16 aaaaaaaaaaaaaaaa
output:
3 11 11000011 1 3 3 2 2 1 13 111 1229782938247303441
result:
wrong answer 4th numbers differ - expected: '2920', found: '1'