B. Password

题意:

找最长的子串,在前缀、后缀以及中间(不包括首尾字符)出现过。

#include<bits/stdc++.h>
using namespace std;
void zft(string s) {
	int n=(int)s.length();
	vector<int>z(n);
	for(int i=1,l=0,r=0;i<n;++i) {
		if(i<=r&&z[i-l]<r-i+1) z[i]=z[i-l];
		else {
			z[i]=max(0,r-i+1);
			while(i+z[i]<n&&s[z[i]]==s[i+z[i]]) ++z[i];
		}
		if(i+z[i]-1>r) l=i,r=i+z[i]-1;
	}
	int x(0),ans(0),a(0),b(0);
	for(int i=1;i<n;++i) {
		if(i+z[i]==n) {
			if(z[i]>a) {
				b=a;
				a=z[i];
			}
			else if(z[i]>b) b=z[i];
		}
		else if(z[i]>x) x=z[i];
	}
	if(x>=a) ans=a;
	else ans=b;
	if(ans) cout<<s.substr(0,ans)<<'\n';
	else cout<<"Just a legend\n";
}
int main() {
	cin.sync_with_stdio(false);
	cin.tie(nullptr),cout.tie(nullptr);
	string s;
	cin>>s;
	zft(s);
}
z函数 文章被收录于专栏

null

全部评论

相关推荐

Jcwemz:中软证书写单行,考了什么学了什么相关技术栈的内容就说自己会什么, 没实习就包装实习简历,将项目经历写成实习做的,项目时间拉长,项目成果具体化,测试的项目成果无非就是写了多少用例查出了多少bug,重要的不是实习了多久,而是你会多少东西,你能表达的就都是你的。 cet4,随便找个地方标上就好了,不用写单行。 粗略建议,我也不在行,觉得对的可以采纳
实习,投递多份简历没人回...
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务