题目大意:告诉你n个字符串以及这些字符串在字符串s中出现的位置(x1,x2.....xn),要求在满足上述条件的情况下,求出字典序最小的字符串s。

解题思路:主要问题是,如果直接模拟是会超时的,比如vvvvvvvvvv 3 1 2 3这样就有大量重复(因为题目说了这些字符串位置不会相互矛盾,所以已经有了字符的地方可以不用管了),每次都重复了len-1的长度,如果这段字符串长度为1e6那很容易就超时了。所以这里添加一个pre记录上一次字符串的末尾位置(因为题目说了给出的位置时递增的),每次比较一下开始位置xi和pre+1的大小取较大的为起始的字符添加点。特意画了张丑图:

Codeforces Round #423 Div. 2 C-String Reconstruction(思维)-LMLPHP

代码:

 #include<stdio.h>
#include<cstring>
const int N=2e6+; char tmp[N];
char s[N];
int idx[N]; int max(int a,int b){
return a>b?a:b;
} int main(){
memset(s,'#',sizeof(s));
int n,mlen=-;
scanf("%d",&n);
int num=;
for(int i=;i<=n;i++){
int m,pre=-;//pre记录上一次字符串的末尾位置
scanf("%s %d",tmp,&m);
int len=strlen(tmp)-;
while(m--){
int pos,x;
scanf("%d",&x);
mlen=max(mlen,x+len);
pos=max(pre+,x);
for(int j=pos;j<=x+len;j++){
s[j]=tmp[j-pos];
num++;
}
//存储上一次末尾位置
pre=x+len;
}
}
for(int i=;i<=mlen;i++){
if(s[i]=='#')
s[i]='a';
}
s[mlen+]='\0';
printf("%s\n",s+);
}
05-20 20:41