QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#211635#6635. Strange KeyboardkkioWA 398ms107336kbC++202.6kb2023-10-12 19:37:192023-10-12 19:37:20

Judging History

你现在查看的是最新测评结果

  • [2023-10-12 19:37:20]
  • 评测
  • 测评结果:WA
  • 用时:398ms
  • 内存:107336kb
  • [2023-10-12 19:37:19]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxk=5005,maxn=1e6+10;
const ll inf=1e18;
int ch[maxn][26],tot,n,K;
vector<int> leaf[maxn];
string s[maxn],T;
vector<int> Len;
bool vis[maxk];
ll dis[maxk],val[maxn];
int dep[maxn];
inline int getpre(int x)
{
    if(~val[x])return val[x];
    val[x]=inf;
    for(int v:leaf[x])
    {
        int len=dep[v]-dep[x];
        val[x]=min(val[x],dis[K-len%K]+(len+K-1)/K+1);
    }
    return val[x];
}
ll dp[maxn];
void solve()
{
    cin>>n>>K;
    Len.clear();
    for(int i=1;i<=n;i++)
        cin>>s[i],Len.push_back(s[i].size());
    cin>>T;
    sort(Len.begin(),Len.end());
    Len.resize(unique(Len.begin(),Len.end())-Len.begin());
    memset(dis,0x3f,sizeof dis);
    dis[K]=0;
    dis[0]=0;
    for(int l:Len)
    {
        if(l==0)continue;
        for(int i=0;i<K;i++)vis[i]=0;
        for(int i=0;i<K;i++)
            if(!vis[i])
            {
                vector<int> cy;
                int now=i;
                int z=l%K;
                do{
                    cy.push_back(now);
                    vis[now]=1;
                    now+=z;while(now>=K)now-=K;
                }while(now!=i);
                int len=cy.size();
                for(int i=0;i<len;i++)cy.push_back(cy[i]);
                for(int i=0;i<cy.size()-1;i++)dis[cy[i+1]]=min(dis[cy[i+1]],dis[cy[i]]+(cy[i]+l>=K?(cy[i]+l-cy[i+1])/K+1:1));
            }
    }
    tot=0;memset(ch[0],0,sizeof ch[0]);
    for(int i=1;i<=n;i++)
    {
        int now=0;
        vector<int> path;
        for(int j=0;j<s[i].size();j++)
        {
            int c=s[i][j]-'a';
            if(!ch[now][c])
            {
                ++tot;ch[now][c]=tot;
                dep[tot]=dep[now]+1;
                memset(ch[tot],0,sizeof ch[tot]);
                val[tot]=-1;
                leaf[tot].clear();
            }
            now=ch[now][c];
            path.push_back(now);
        }
        for(int v:path)leaf[v].push_back(now);
    }
    for(int i=1;i<=T.size();i++)dp[i]=inf;
    for(int i=0;i<T.size();i++)
    {
        int now=0;
        for(int j=i;j<T.size();j++)
        {
            int c=T[j]-'a';
            if(!ch[now][c])break;
            now=ch[now][c];
            dp[j+1]=min(dp[j+1],dp[i]+getpre(now));
        }
    }
    if(dp[(int)T.size()]!=inf)printf("%lld\n",dp[(int)T.size()]);
    else puts("-1");
}
int main()
{
	//freopen("data.in","r",stdin);
	//freopen("1.out","w",stdout);
    int T;scanf("%d",&T);
    while(T--)solve();
    return 0;
}
/*
1
5 4
cabd
bcca
ddab
dabd
cba
cbc
*/

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 13ms
memory: 63080kb

input:

2
2 3
defgh
abc
abcde
1 1
a
b

output:

3
-1

result:

ok 2 number(s): "3 -1"

Test #2:

score: 0
Accepted
time: 76ms
memory: 70656kb

input:

1
1413 4867
yumnkkghwtqnhpmmsbfwypcwudihegsvtdaykueuqozagpgdnhbwzoqrqswyctzonwmjdjmmpyzbyihhpyznmqltcuckqmcybbdafoexqztxhzlfjowznisnxtgoiqjztogldyegajmegalqgawrzotuntocmsagvkzdnwhmaewuxiuhvintpzwyrkgapnmegpveyuuorrfvrfakjyetfaoqtvwghlslsvmahrkvzkwpaviufknrpuapicqdnn
yumnkkghwtqnhpmmsbfwypcwudihegsvt...

output:

10

result:

ok 1 number(s): "10"

Test #3:

score: 0
Accepted
time: 147ms
memory: 64144kb

input:

10
446 4905
afigcjhcgagabbiccehjcjajigghgbjjadccicghggijjdfeciaccgheedjdhgfjdfdbgidbbdjaiehhceeehchhabhaideggjbjajgfgicfdggahhbjgdebccbgbiedhehaebdccdfdffaacjcfbgjeegbahhbgcdjigijajheidchbddicehhhjbeiaajgedhdcjiefdgdbjjfaegheeidieheecaicciaajbabiidcecefgiicccdidegeica
afigcjhcgagabbiccehjcjajigghgbj...

output:

3
2
2
11
6
5
1
1
1
1

result:

ok 10 numbers

Test #4:

score: 0
Accepted
time: 398ms
memory: 61260kb

input:

100
140 4879
baabaababbababbaabababaaababbbabbbbbbabbababbbabbbbabbbbbbaabbbbbbbbabaabbbaabaabbbaabbabaabaabbbabbbababbbaabbabaaaaabbaaabbbabb
baa
baabaababbababbaabababaaababbbabbbbbbabbab
baabaababbababbaabababaaabab
baabaababbababbaabababaaababbbabbb
baabaababbababbaabababaaababbbabbbbbbabbababbb...

output:

1
1
1
1
3
1
1
1
1
1
1
3
2
1
1
1
2
1
1
2
1
1
1
1
1
1
1
1
1
4
3
2
1
2
1
1
1
1
1
2
1
1
1
3
1
1
1
2
1
1
1
2
3
1
1
1
2
1
1
1
1
1
1
1
1
3
2
3
1
3
1
1
2
1
2
3
2
1
1
1
3
2
1
2
1
1
1
1
1
1
1
1
1
1
1
1
2
1
4
1

result:

ok 100 numbers

Test #5:

score: 0
Accepted
time: 92ms
memory: 107336kb

input:

1
7 4864
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa...

output:

205

result:

ok 1 number(s): "205"

Test #6:

score: 0
Accepted
time: 76ms
memory: 99568kb

input:

10
7 4923
baaabbabbbabbbbbabaabaabababbabbaaaabbaaabbbbabbaaababaaaaabaaabbabbbabbaaaabbaabbbaabbaaababaaababbabaababbaababbabaaabaabbaaabaaaababbabbabaabaabaabaabbbbaabaabbbaababbabbabaaaabbbaabbbaaaabaaaaababbaabaaaaababbbbaaaabbbaababbaabbabaabaaaaababaababaabaaaaabababababbabbbabababaaabaababbaa...

output:

4287
228
3671
549
129
372
475
534
336
288

result:

ok 10 numbers

Test #7:

score: -100
Wrong Answer
time: 109ms
memory: 67192kb

input:

100
7 4807
abbababaababbaabbabbaabaababbaaababaabaaabbaaaabababbbaabbaaabababbaabaabbaaaaabbbbaabbbaaabbbbabaabbbaaaaabbbaabbaaaabbaaababbaaabbbbabaabbababababbbabaaabaaaabbbbabbabbbbbaabaaabaababbabaaabbaabbabbabaaababbbabbabbbaababaabaaaabaaabbbbabbaabaababbbabbbbaaaabbabbbaabbaabbbbb
aaaaababaaab...

output:

45
32
11
4
2475
132
50
330
20
6
99
25
126
6
4
14
74
108
208
11
5
67
166
2822
178
1307
548
92
386
493
279
2415
255
262
567
215
46
113
31
651
17
4
8
21
12
100
69
152
15
55
521
146
11
13
181
-77304168448
442
1839
2
5
31
26
122
696
280
77
1
839
11
273
7
178
421
228
6
6
82
116
1
-50545033216
293
519
5
16...

result:

wrong answer 56th numbers differ - expected: '-1', found: '-77304168448'