BZOJ_4278_[ONTAK2015]Tasowanie_后缀数组

Description

给定两个数字串A和B,通过将A和B进行二路归并得到一个新的数字串T,请找到字典序最小的T。

Input

第一行包含一个正整数n(1<=n<=200000),表示A串的长度。
第二行包含n个正整数,其中第i个数表示A[i](1<=A[i]<=1000)。
第三行包含一个正整数m(1<=m<=200000),表示B串的长度。
第四行包含m个正整数,其中第i个数表示B[i](1<=B[i]<=1000)。

Output

输出一行,包含n+m个正整数,即字典序最小的T串。

Sample Input

6
1 2 3 1 2 4
7
1 2 2 1 3 4 3

Sample Output

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


类似某道奶牛题,这道更简单一些?

归并的时候每次要选当前到串末尾字典序小的那个,并且每次选一个字符。

把两个串拼起来,求一遍后缀数组,这样就可以快速的知道两个后缀的字典序大小关系。

模拟即可。

代码:

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define N 400050
int ws[N],wv[N],wa[N],wb[N],r[N],n,Rank[N],height[N],sa[N],m,la,lb;
int a[N],b[N];
void build_suffix_array() {
m=1002;
int i,j,p,*x=wa,*y=wb,*t;
for(i=0;i<m;i++) ws[i]=0;
for(i=0;i<n;i++) ws[x[i]=r[i]]++;
for(i=1;i<m;i++) ws[i]+=ws[i-1];
for(i=n-1;i>=0;i--) sa[--ws[x[i]]]=i;
for(p=j=1;p<n;j<<=1,m=p) {
for(p=0,i=n-j;i<n;i++) y[p++]=i;
for(i=0;i<n;i++) if(sa[i]-j>=0) y[p++]=sa[i]-j;
for(i=0;i<n;i++) wv[i]=x[y[i]];
for(i=0;i<m;i++) ws[i]=0;
for(i=0;i<n;i++) ws[wv[i]]++;
for(i=1;i<m;i++) ws[i]+=ws[i-1];
for(i=n-1;i>=0;i--) sa[--ws[wv[i]]]=y[i];
for(t=x,x=y,y=t,i=p=1,x[sa[0]]=0;i<n;i++) {
if(y[sa[i]]==y[sa[i-1]]&&y[sa[i]+j]==y[sa[i-1]+j]) x[sa[i]]=p-1;
else x[sa[i]]=p++;
}
}
for(i=1;i<n;i++) Rank[sa[i]]=i;
for(i=p=0;i<n-1;height[Rank[i++]]=p)
for(p?p--:0,j=sa[Rank[i]-1];r[i+p]==r[j+p];p++);
}
int main() {
scanf("%d",&la);
int i;
for(i=0;i<la;i++) {
scanf("%d",&a[i]);
r[n++]=a[i];
}
scanf("%d",&lb);
r[n++]=1001;
for(i=0;i<lb;i++) {
scanf("%d",&b[i]);
r[n++]=b[i];
}
r[n++]=0;
build_suffix_array();
int j=0,k=la+1;
while(j<la&&k<n-1) {
if(Rank[j]<Rank[k]) printf("%d ",r[j++]);
else printf("%d ",r[k++]);
}
while(j<la) printf("%d ",r[j++]);
while(k<n-1) printf("%d ",r[k++]);
}

最新文章

  1. php函数强大的 strtotime
  2. ABP理论学习之N层架构
  3. 深入理解DOM节点类型第一篇——12种DOM节点类型概述
  4. shell生成随机数的几种方法
  5. [No000050]练习一万小时便能成为天才
  6. 十天冲刺---Day3
  7. linux定时执行任务 转
  8. 【rman,1】经典案例增量备份
  9. 关于并行计算的Scan操作
  10. as3 操作图片,获取,设置实际像素,扣除透明区域
  11. vue.js - 奇怪的 event 对象
  12. char和unsigned char--数据类型区别
  13. github总结(4)--关于git reset --hard这个命令的惨痛教训
  14. NC 6.X笔记(编辑中)
  15. 前端自动化准备和详细配置(NVM、NPM/CNPM、NodeJs、NRM、WebPack、Gulp/Grunt、Git/SVN)
  16. 爬虫BS4—淘女郎
  17. System.SerializableAttribute
  18. linux关闭的时候出现异常: java.net.ConnectException: 拒绝连接 (Connection refused)
  19. Win7 开机自动启动Outlook2010
  20. BZOJ 4808: 马(二分图最大点独立集)

热门文章

  1. 用canal监控binlog并实现mysql定制同步数据的功能
  2. VC/MFC中计算程序运行时间
  3. IronPython 与C#交互
  4. [Javascript] Replicate JavaScript Constructor Inheritance with Simple Objects (OLOO)
  5. hdu 4707 Pet(DFS &amp;amp;&amp;amp; 邻接表)
  6. 【POJ 3292】 Semi-prime H-numbers
  7. iOS常用网络库收集
  8. POJ 2586 Y2K Accounting Bug(枚举大水题)
  9. Android IntentService的使用和源代码分析
  10. spring cloud config 属性加解密