提交记录 20379


用户 题目 状态 得分 用时 内存 语言 代码长度
c20150005 1006. 【模板题】后缀排序 Wrong Answer 0 105.114 ms 4236 KB C++17 1.09 KB
提交时间 评测时间
2023-10-13 21:21:28 2023-10-13 21:21:37
#include<bits/stdc++.h>
using namespace std;
const int N=1e6+6;
using ull=unsigned long long;
char ch[N];
int n,rk[N],sa[N],ht[N];
ull hsh[N],pw[N],p=131;
bool cmp(int a,int b){
	// if(ch[bl[be[a]]]==ch[bl[be[b]]]){
	// 	int L=min(bl[be[a]]-a,bl[be[b]]-b);
	// 	a+=L,b+=L;
	// }
	// while(a<n&&b<n&&ch[a]==ch[b])a++,b++;
	// if(a>=n)return 1;
	// if(b>=n)return 0;
	// return ch[a]<ch[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;
	}
	// cerr<<a<<" "<<b<<" : "<<ans<<endl;
	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]-28)*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]);
	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 #141.19 us56 KBWrong AnswerScore: 0

Subtask #1 Testcase #239.63 us60 KBWrong AnswerScore: 0

Subtask #1 Testcase #336.92 us60 KBWrong AnswerScore: 0

Subtask #1 Testcase #442.83 us60 KBWrong AnswerScore: 0

Subtask #1 Testcase #542.59 us60 KBWrong AnswerScore: 0

Subtask #1 Testcase #642.41 us60 KBWrong AnswerScore: 0

Subtask #1 Testcase #785.15 ms3 MB + 784 KBWrong AnswerScore: 0

Subtask #1 Testcase #899.741 ms3 MB + 972 KBWrong AnswerScore: 0

Subtask #1 Testcase #995.569 ms3 MB + 836 KBWrong AnswerScore: 0

Subtask #1 Testcase #1059.594 ms2 MB + 524 KBWrong AnswerScore: 0

Subtask #1 Testcase #1162.572 ms2 MB + 564 KBWrong AnswerScore: 0

Subtask #1 Testcase #1252.726 ms4 MB + 140 KBWrong AnswerScore: 0

Subtask #1 Testcase #1371.826 ms4 MB + 108 KBWrong AnswerScore: 0

Subtask #1 Testcase #1497.165 ms3 MB + 864 KBWrong AnswerScore: 0

Subtask #1 Testcase #15105.114 ms3 MB + 880 KBWrong AnswerScore: 0

Subtask #1 Testcase #1661.374 ms4 MB + 140 KBWrong AnswerScore: 0

Subtask #1 Testcase #1767.924 ms4 MB + 140 KBWrong AnswerScore: 0

Subtask #1 Testcase #1868.341 ms4 MB + 140 KBWrong AnswerScore: 0


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