fzu2137 字符串hash或后缀数组-程序员宅基地

技术标签: 数据结构  hash  algorithm  

字符串hash

//#pragma comment(linker, "/STACK:102400000,102400000")
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#include<cmath>
#include<cctype>
#include<string>
#include<algorithm>
#include<iostream>
#include<ctime>
#include<map>
#include<set>
using namespace std;
#define MP(x,y) make_pair((x),(y))
#define PB(x) push_back(x)
typedef long long LL;
typedef unsigned long long ULL;
/* ****************** */
//const int INF=1000111222;
const double INFF=1e100;
const double eps=1e-8;
//const LL mod=1000000007;
const int mod=1000000007;
const int NN=100010;
const int MM=100010;
/* ****************** */

const ULL MOD=131;

ULL mul[NN];
ULL a[NN];
char ss[NN];

int main()
{
    int cas;
    int n,i,j,j1;
    ULL ans,t1,t2,t;

    mul[0]=1;
    for(i=1;i<NN;i++)
    {
        mul[i]=mul[i-1]*MOD;
    }

    scanf("%d",&cas);
    while(cas--)
    {
        scanf("%s",ss+1);
        n=strlen(ss+1);

        for(i=1;i<=n;i++)
        {
            a[i]=mul[i]*ss[i];
        }

        ans=0;
        for(i=2;i<n;i++)
        {
            j=i-1;
            j1=i+1;
            t1=t2=0;

            for(;j>=1 && j1<=n;j--,j1++)
            {
                if(ss[j]==ss[i] || ss[j1]==ss[i])
                    break;

                t1+=a[j];
                t2+=a[j1];
                if(t1*mul[i+1-j]==t2)
                {
                    t=j1-j+1;
                    ans+=t*t;
                }
            }
        }

        printf("%I64u\n",ans);
     //   cout<<ans<<endl;
    }
    return 0;
}


后缀数组


//#pragma comment(linker, "/STACK:102400000,102400000")
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#include<cmath>
#include<cctype>
#include<string>
#include<algorithm>
#include<iostream>
#include<ctime>
#include<map>
#include<set>
using namespace std;
#define MP(x,y) make_pair((x),(y))
#define PB(x) push_back(x)
typedef long long LL;
typedef unsigned long long ULL;
/* ****************** */
//const int INF=1000111222;
const double INFF=1e100;
const double eps=1e-8;
//const LL mod=1000000007;
const int mod=1000000007;
const int NN=100010;
const int MM=100010;
/* ****************** */

char ss[NN];
int a[NN];

//建立
int wa[NN],wb[NN],wv[NN],wss[NN],sa[NN];
//求高
int rank[NN],height[NN];
//RMQ
int rmq[NN][20],long2[NN];

int cmp(int *r,int a,int b,int l)
{return r[a]==r[b]&&r[a+l]==r[b+l];}
//r[n-1]==0;
void da(int *r,int n,int m)
{
    int i,j,p,*x=wa,*y=wb,*t;
    for(i=0;i<m;i++)wss[i]=0;
    for(i=0;i<n;i++)wss[x[i]=r[i]]++;
    for(i=1;i<m;i++)wss[i]+=wss[i-1];
    for(i=n-1;i>=0;i--)sa[--wss[x[i]]]=i;
    for(j=1,p=1;p<n;j*=2,m=p)
    {
        for(p=0,i=n-j;i<n;i++)y[p++]=i;
        for(i=0;i<n;i++)if(sa[i]>=j)y[p++]=sa[i]-j;

        for(i=0;i<n;i++)wv[i]=x[y[i]];
        for(i=0;i<m;i++)wss[i]=0;
        for(i=0;i<n;i++)wss[wv[i]]++;
        for(i=1;i<m;i++)wss[i]+=wss[i-1];
        for(i=n-1;i>=0;i--)sa[--wss[wv[i]]]=y[i];

        for(t=x,x=y,y=t,p=1,x[sa[0]]=0,i=1;i<n;i++)
            x[sa[i]]=cmp(y,sa[i-1],sa[i],j)?p-1:p++;
    }
    return;
}

void calheight(int *r,int n)
{
    int i,j,k=0;
    for(i=1;i<=n;i++)rank[sa[i]]=i;
    for(i=0;i<n;height[rank[i++]]=k)
        for(k?k--:0,j=sa[rank[i]-1];r[i+k]==r[j+k];k++);
    return;
}

void initRMQ(int n)
{
    int i,j,en;
    long2[1]=0;
    for(i=2;i<=n;i++)
    {
        long2[i]=long2[i-1]+(i==(i&(-i)));
    }
    for(i=1;i<=n;i++)rmq[i][0]=height[i];
    for(j=1;j<=long2[n];j++)
    {
        en=n+1-(1<<j);
        for(i=1;i<=en;i++)
            rmq[i][j]=min(rmq[i][j-1],rmq[ i+(1<<(j-1)) ][j-1]);
    }
}
int ask_lcp(int i,int j)
{
    i=rank[i],j=rank[j];
    if(i>j)swap(i,j);
    i++;
    int k=long2[j-i+1];
    int ans=min(rmq[i][k],rmq[ j+1-(1<<k) ][k]);
    return ans;
}

int main()
{
    int cas;
    int n,i,j,j1,lcp;
    ULL ans,t;
    scanf("%d",&cas);
    while(cas--)
    {
        scanf("%s",ss);
        n=strlen(ss);
        for(i=0;i<n;i++)
        {
            a[i]=ss[i]-'a'+1;
        }
        a[n]=0;
        da(a,n+1,30);
        calheight(a,n);
        initRMQ(n);
        
        ans=0;
        for(i=1;i<n;i++)
        {
            j=i-1;
            j1=i+1;

            for(;j>=0 && j1<n;j--,j1++)
            {
                if(ss[j]==ss[i] || ss[j1]==ss[i])
                    break;

                lcp=ask_lcp(j,i+1);

                if(lcp>=i-j)
                {
                    t=j1-j+1;
                    ans+=t*t;
                }
            }
        }
        printf("%I64u\n",ans);
     //   cout<<ans<<endl;
    }
    return 0;
}


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/ACMmaxx/article/details/15338727

智能推荐

element-ui中table表头和数据未对齐处理_elementui表头与内容不对齐-程序员宅基地

文章浏览阅读307次。element-ui中table表头和数据未对齐处理_elementui表头与内容不对齐

concat函数,concat_ws函数,concat_group函数之间的区别_cancat-程序员宅基地

文章浏览阅读705次。直接上干货:– 建表操作:-- 建表CREATE table 成绩表1(学号 VARCHAR(10),科目 VARCHAR(10),成绩 INTEGER)– 插入数据:INSERT into `成绩表` values -- 插入数据('001','计算机',99),('003','数学',99),('001','数学',99),('001','化学',88),('002','英语',96),('003','语文',76);SELECT * from 成绩表; -- 预览_cancat

基于ssm的宠物领养系统论文-程序员宅基地

文章浏览阅读965次,点赞18次,收藏23次。在网站的整个开发过程中,首先对系统进行了需求分析,设计出系统的主要功能模块,其次对网站进行总体规划和详细设计,最后对宠物领养系统进行了系统测试,包括测试概述,测试方法,测试方案等,并对测试结果进行了分析和总结,进而得出系统的不足及需要改进的地方,为以后的系统维护和扩展提供了方便

python物联网全栈开发实践_《从芯片到云端:Python物联网全栈开发实践(博文视点出品)》(刘凯)【摘要 书评 试读】- 京东图书...-程序员宅基地

文章浏览阅读61次。前几年国内引进了Chris Anderson的《创客:新工业革命》。打那时候开始,国内流行起“创客”风潮。“创客”这个词果真是一个洋气的舶来品,很多国人姑且把它看成硬件创业的预备役。但是大洋彼岸原产地的人们倒是朴实得可爱:织个毛衣,搞个室内大棚蔬菜。当然高科技类的自然少不了捣鼓一下机床,焊一块板子,这更像是一种DIY的怀旧文化:更加纯粹和快乐。做一名纯粹的创客并不容易,毕竟要抽出一定的时间和精力。..._python 物联网全栈开发

免费开源!细节拉满的一个2D实时水面反射效果Demo,基于Cocos Creator 3.5-程序员宅基地

文章浏览阅读464次。引言:插件Easy NavMesh、BenchMark 性能检测的作者孙二喵,从开发者王师傅的论坛分享中获得启发,实现了 2D 实时水面反射效果,Demo 免费开源。2D 实时水面反射Demo 效果前几天看到论坛大佬的 2D 水面 Shader 教程(注:后文有详细内容),效果挺好的,就跟着在 Cocos Creator 3.5.2 中做了一个,实现 2D 实时水面反射,并支持角色移动,开箱即用..._cocos creator 2d镜面反射

SIMATIC C7-635西门子触摸屏维修6ES7635-2EB02-0AE3-程序员宅基地

文章浏览阅读345次,点赞9次,收藏8次。西门子的ET200系列是采用PROFIBUS-DP协议的分布式I/O,应用时,S7PLC作为DP主站,通过带有集成DP接口的CPU315-2DP接到PROFIBUS总线,ET200作为DP从站接到PROFIBUS。黑液蒸发把洗选工段产生的副产品------稀黑液高度浓缩后送燃烧工段处理,碱回收设备的工况恶劣,尤其是腐蚀性和黑液结垢问题很为棘手,平稳整个工艺过程的运行,使设备工作在合理,工艺参数范围内是减慢结垢速度、延长设备使用寿命的方法。系统采用主站加从站的结构,可使系统造价降低,并且扩展灵活。

随便推点

充分理解boost库_boost如何理解-程序员宅基地

文章浏览阅读177次。用C++做后台开发有哪些需要注意的问题说起后台开发,严格地说和用什么语言开发没有必然的关系。比如说网络游戏的后台,用C++开发的有很多,但用Java开发的也不少,而且在某些情况下,用Java做服务器效果还较好。其实,如果说用C++开发后台,可能更多的是从项目需要的角度考虑。毕竟现在能够找到一个好的C++程序员也不是一件容易的事,所以首先肯定的一点是用C++开发后台可能面临较大的人力成本。用C+..._boost如何理解

运维自动化之puppet-dashboard(7)-程序员宅基地

文章浏览阅读80次。安装配置:yum -y install rubygem-rake ruby-mysqlyum localinstall puppet-dashboardgem install rakemysql授权create database dashboard character set utf8;grant all on dashboard.* TO 'dashboard'@'%' i..._dashboard 自动化的应用

《数据结构 C语言版 严蔚敏 第2版》:树和二叉树_数据结构c语言版严蔚敏第二版-程序员宅基地

文章浏览阅读373次,点赞4次,收藏2次。《数据结构 C语言版 严蔚敏 第2版》:树和二叉树_数据结构c语言版严蔚敏第二版

你的css选择器可视化备忘录-程序员宅基地

文章浏览阅读808次,点赞19次,收藏27次。这个 CSS 规则选择了在另一个元素之后出现的任何元素(除了容器中的第一个元素),并在顶部应用了一定的边距,有效地使元素均匀地间隔开来。有一种望而却步的赶脚。,因为它会匹配页面上的所有元素,包括嵌套元素,这可能会增加浏览器的渲染负担。这使得子选择器非常有用,因为它可以帮助我们更精确地定位特定层次结构的元素,并应用相应的样式。允许我们选择与指定元素具有相同父元素且位于其后面的所有兄弟元素,而不仅仅是直接的兄弟元素。例如,如果我们想为页面上的所有元素设置相同的字体样式,我们可以使用通用选择器来实现。

使用poi导出嵌套对象(一对多、多对多)_execl poi导出 1对多的关系-程序员宅基地

文章浏览阅读4k次,点赞4次,收藏13次。Workbook workbook = new WorkbookBuilder(new SXSSFWorkbook()) .setDefaultRowHeight(20) .matchingAll() .setFontHeight(12) .setFontName("微软雅黑") .setVerticalAlignment(VerticalAlignment.CENTER) .setAlignment(HorizontalAlignment.CENTER) .se._execl poi导出 1对多的关系

pandas基础学习-程序员宅基地

文章浏览阅读27次。作为参数,0表示第一行,1表示第2行,以此类推。DataFrame意为数据框架,是Pandas库中的一种数据结构,类似于二维表,由行和列组成,与Series一样支持多种数据类型。loc属性,以列名(columns)和行名(index)作为参数,当只有一个参数时,默认是行名,即抽取整行数据,包括所有列。修改行标题,使用DataFrame对象的index属性直接赋值,,或者使用DataFrame对象的rename方法修改行标题。缺失值的处理方式有不处理、删除、填充或替换、插值(均值、中位数、众数等填补)_pandas基础