提交记录 20391


用户 题目 状态 得分 用时 内存 语言 代码长度
c20150005 1006. 【模板题】后缀排序 Wrong Answer 0 105.027 ms 4216 KB C++14 899 B
提交时间 评测时间
2023-10-13 21:50:32 2023-10-13 21:50:40
#include<bits/stdc++.h>
using namespace std;
const int N=1e5+6;
using ull=unsigned long long;
char ch[N];
int n,rk[N],sa[N],ht[N];
//const ull mod=1e9+7;
ull hsh[N],pw[N],p=1331;
bool cmp(int a,int b){
	int fl=0;
	if(a>b)swap(a,b),fl=1;
	int l=0,r=n-b-1,ans=-1;
	while(r>=l){
		int mid=(l+r)>>1;
		if((hsh[a+mid]-hsh[a-1])*pw[b-a]==(hsh[b+mid]-hsh[b-1]))
		ans=mid,l=mid+1;
		else r=mid-1;
	}
	if(b+ans==n-1)return fl;
	return fl^(ch[a+ans+1]<ch[b+ans+1]);
}
int main(){
	cin>>ch;
	n=strlen(ch);
	pw[0]=1;
	for(int i=1;i<n;i++)pw[i]=pw[i-1]*p;
	for(int i=0;i<n;i++)hsh[i]=((ch[i]-'a')*pw[i]+hsh[i-1]);
	for(int i=0;i<n;i++)sa[i]=i;
	stable_sort(sa,sa+n,cmp);
	for(int i=0;i<n;i++)rk[sa[i]]=i,printf("%d ",sa[i]+1);
	puts("");
	for(int i=0,k=0;i<n;i++){
		if(rk[i]==0)continue;
		k-=!!k;
		while(ch[i+k]==ch[sa[rk[i]-1]+k])k++;
		ht[rk[i]]=k;
	}
	for(int i=1;i<n;i++)printf("%d ",ht[i]);
	return 0;
}

CompilationN/AN/ACompile OKScore: N/A

Subtask #1 Testcase #143.39 us56 KBWrong AnswerScore: 0

Subtask #1 Testcase #237.79 us60 KBAcceptedScore: 0

Subtask #1 Testcase #336.84 us60 KBAcceptedScore: 0

Subtask #1 Testcase #442.47 us60 KBAcceptedScore: 0

Subtask #1 Testcase #541.88 us60 KBAcceptedScore: 0

Subtask #1 Testcase #643.71 us60 KBAcceptedScore: 0

Subtask #1 Testcase #785.316 ms3 MB + 764 KBAcceptedScore: 0

Subtask #1 Testcase #899.447 ms3 MB + 952 KBAcceptedScore: 0

Subtask #1 Testcase #995.544 ms3 MB + 816 KBAcceptedScore: 0

Subtask #1 Testcase #1059.977 ms2 MB + 524 KBAcceptedScore: 0

Subtask #1 Testcase #1162.863 ms2 MB + 564 KBAcceptedScore: 0

Subtask #1 Testcase #1252.572 ms4 MB + 120 KBAcceptedScore: 0

Subtask #1 Testcase #1371.859 ms4 MB + 88 KBAcceptedScore: 0

Subtask #1 Testcase #1497.261 ms3 MB + 844 KBAcceptedScore: 0

Subtask #1 Testcase #15105.027 ms3 MB + 860 KBAcceptedScore: 0

Subtask #1 Testcase #1661.351 ms4 MB + 120 KBAcceptedScore: 0

Subtask #1 Testcase #1767.891 ms4 MB + 120 KBAcceptedScore: 0

Subtask #1 Testcase #1868.291 ms4 MB + 120 KBAcceptedScore: 0


Judge Duck Online | 评测鸭在线
Server Time: 2025-09-13 09:11:59 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠