ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

「SNOI2019」字符串

2019-10-13 20:55:09  阅读:319  来源: 互联网

标签:nxt int 位置 原串 字符串 SNOI2019 cmp


题目链接:Click here

Solution

事实上,我们发现我们比较的两个字符串是极为相似的

设我们当前要比较的两个字符串为\(s_x\)和\(s_y\),而他们不同的地方就在于原串\(x\sim y\)的部分

而这一部分也是十分相似的,准确的来说,他们对应的位置在原串中事实上是位置相邻的点

则我们只需要记录每个点后第一个相邻位置值不同的位置,再魔改一下\(cmp\)就行了

Code:

#include<bits/stdc++.h>
using namespace std;
const int N=1e6+11;
char s[N];
int n,nxt[N],p[N];
inline bool cmp(int x,int y){
    int v=nxt[min(x,y)];
    if(v<max(x,y)){
        if(x<y) return s[v+1]<s[v];
        else return s[v]<s[v+1];
    }else return x<y;
}
int read(){
    int x=0,f=1;char ch=getchar();
    while(!isdigit(ch)){if(ch=='-')f=-f;ch=getchar();}
    while(isdigit(ch)){x=x*10+ch-48;ch=getchar();}
    return x*f;
}
signed main(){
    n=read();
    scanf("%s",s+1);nxt[n]=n;
    for(int i=n-1;i;i--){
        if(s[i]!=s[i+1]) nxt[i]=i;
        else nxt[i]=nxt[i+1];
    }
    for(int i=1;i<=n;i++) p[i]=i;
    sort(p+1,p+n+1,cmp);
    for(int i=1;i<=n;i++) printf("%d ",p[i]);
    return 0;
}

标签:nxt,int,位置,原串,字符串,SNOI2019,cmp
来源: https://www.cnblogs.com/NLDQY/p/11668261.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有