QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#135701#6635. Strange KeyboardPhantomThresholdTL 419ms11924kbC++201.7kb2023-08-05 22:48:122023-08-05 22:48:14

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-08-05 22:48:14]
  • 评测
  • 测评结果:TL
  • 用时:419ms
  • 内存:11924kb
  • [2023-08-05 22:48:12]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;

const int maxn = 1010000;
const int maxt = 5050;
const int inf  = 1e9;

int n,K;
int len[maxn],id[maxn];
int rt,tr[maxn][26],fa[maxn],f[maxn],tot;
int newnode()
{
	++tot;
	for(int i=0;i<26;i++) tr[tot][i]=0;
	fa[tot]=0;
	f[tot]=inf;
	return tot;
}
int dis[maxt],a[maxt];
priority_queue< pair<int,int> >q;

string T; int tn;
int g[maxt];

signed main()
{
	ios_base::sync_with_stdio(false);
	int Tcase; cin>>Tcase;
	
	while(Tcase--)
	{
		cin>>n>>K;
		for(int i=0;i<K;i++) a[i]=inf;
		tot=0;
		rt=newnode();
		for(int i=1;i<=n;i++)
		{
			string str; cin>>str;
			len[i]=str.size();
			a[len[i]%K]= min( a[len[i]%K], len[i]/K+1 );
			int now=rt;
			for(auto c:str)
			{
				int j=c-'a';
				if(!tr[now][j]) 
				{
					tr[now][j]=newnode();
					fa[tr[now][j]]=now;
				}
				now=tr[now][j];
			}
			id[i]=now;
		}
		cin>>T; tn=T.size();
		
		for(int i=0;i<K;i++) dis[i]= inf;
		dis[0]=0; q.push( make_pair( dis[0],0 ) );
		while(!q.empty())
		{
			auto [D,i]= q.top(); q.pop();
			if( D!=dis[i] ) continue;
			for(int k=0;k<K;k++)
			{
				int j= (i+k)%K, jc=D+a[k]+(i+k>=K);
				if( dis[j]>jc )
				{
					dis[j]=jc;
					q.push(make_pair(dis[j],j));
				}
			}
		}
		
		for(int i=1;i<=n;i++)
		{
			int l=0,x=id[i];
			while(x!=rt)
			{
				f[x]=min(f[x], l/K+ ( l%K==0?0:dis[K-l%K]+1 ) );
				x=fa[x]; l++;
			}
		}
		
		for(int i=0;i<=tn;i++) g[i]=inf;
		g[0]=0;
		for(int i=0;i<tn;i++)
		{
			int now=rt;
			for(int j=1;j<=tn-i;j++)
			{
				int c=T[i+j-1]-'a';
				if(tr[now][c]==0) break;
				now=tr[now][c];
				g[i+j]=min(g[i+j],g[i]+1+f[now]);
			}
		}
		cout<< (g[tn]==inf?-1:g[tn]) <<'\n';
	}
	
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 11728kb

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: 46ms
memory: 11924kb

input:

1
1413 4867
yumnkkghwtqnhpmmsbfwypcwudihegsvtdaykueuqozagpgdnhbwzoqrqswyctzonwmjdjmmpyzbyihhpyznmqltcuckqmcybbdafoexqztxhzlfjowznisnxtgoiqjztogldyegajmegalqgawrzotuntocmsagvkzdnwhmaewuxiuhvintpzwyrkgapnmegpveyuuorrfvrfakjyetfaoqtvwghlslsvmahrkvzkwpaviufknrpuapicqdnn
yumnkkghwtqnhpmmsbfwypcwudihegsvt...

output:

10

result:

ok 1 number(s): "10"

Test #3:

score: 0
Accepted
time: 419ms
memory: 11820kb

input:

10
446 4905
afigcjhcgagabbiccehjcjajigghgbjjadccicghggijjdfeciaccgheedjdhgfjdfdbgidbbdjaiehhceeehchhabhaideggjbjajgfgicfdggahhbjgdebccbgbiedhehaebdccdfdffaacjcfbgjeegbahhbgcdjigijajheidchbddicehhhjbeiaajgedhdcjiefdgdbjjfaegheeidieheecaicciaajbabiidcecefgiicccdidegeica
afigcjhcgagabbiccehjcjajigghgbj...

output:

3
2
2
11
6
5
1
1
1
1

result:

ok 10 numbers

Test #4:

score: -100
Time Limit Exceeded

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

result: