看了求后缀数组的倍增法之后很快就理解了,但是自己写的倍增法用map排序还是超时了。然后看了两天别人写的模板,题目是通过了,但感觉代码还是半懂半背的。以后多熟悉熟悉吧;

  • 后缀数组

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = 1e6 + ;
    char s[MAXN];
    int sa[MAXN], rk[MAXN], height[MAXN];
    void getSa(char* s, int* sa, int n, int m) {
    int* x = (int*)calloc(MAXN, sizeof(int));
    int* y = (int*)calloc(MAXN, sizeof(int));
    int* cnt = (int*)calloc(MAXN, sizeof(int));
    for (int i = ; i <= n; i++) {
    cnt[x[i] = s[i]]++;
    }
    for (int i = ; i <= m; i++) {
    cnt[i] += cnt[i - ];
    }
    for (int i = n; i; i--) {
    sa[cnt[x[i]]--] = i;
    }
    for (int j = ; j < n; j <<= ) {
    int num = ;
    for (int i = n - j + ; i <= n; i++) {
    y[++num] = i;
    }
    for (int i = ; i <= n; i++) {
    if (sa[i] > j) {
    y[++num] = sa[i] - j;
    }
    }
    for (int i = ; i <= m; i++) {
    cnt[i] = ;
    }
    for (int i = ; i <= n; i++) {
    cnt[x[i]]++;
    }
    for (int i = ; i <= m; i++) {
    cnt[i] += cnt[i - ];
    }
    for (int i = n; i; i--) {
    sa[cnt[x[y[i]]]--] = y[i];
    }
    swap(x, y);
    x[sa[]] = num = ;
    for (int i = ; i <= n; i++) {
    if (y[sa[i]] != y[sa[i - ]] || y[sa[i] + j] != y[sa[i - ] + j]) {
    x[sa[i]] = ++num;
    } else {
    x[sa[i]] = num;
    }
    }
    if (num >= n) {
    break;
    }
    m = num;
    }
    free(x);
    free(y);
    free(cnt);
    }
    void getHeight(char* s, int* sa, int* rk, int* height, int n) {
    for (int i = ; i <= n; i++) {
    rk[sa[i]] = i;
    }
    int k = ;
    for (int i = ; i <= n; i++) {
    k = k != ? k - : k;
    int j = sa[rk[i] - ];
    while (s[i + k] == s[j + k]) {
    k++;
    }
    height[rk[i]] = k;
    }
    }
    int main() {
    gets(s + );
    int len = strlen(s + );
    getSa(s, sa, len, );
    // getHeight(s, sa, rk, height, len);
    for (int i = ; i < len; i++) {
    printf("%d ", sa[i]);
    }
    printf("%d\n", sa[len]);
    /*
    for (int i = 1; i < len; i++) {
    printf("%d ", rk[i]);
    }
    printf("%d\n", rk[len]);
    for (int i = 1; i < len; i++) {
    printf("%d ", height[i]);
    }
    printf("%d\n", height[len]);
    */
    return ;
    }

    附带rank数组和height数组,本题不需要。

洛谷-P3809-后缀排序(后缀数组)的更多相关文章

  1. [洛谷P3809]【模板】后缀排序

    [洛谷P3809][模板]后缀排序 题目大意: 对于给定的长度为\(n(n\le10^6)\)的字符串求后缀数组\(sa[i]\). 思路: 倍增+快排构造后缀数组.代码参考<挑战程序设计竞赛& ...

  2. UOJ #35. 后缀排序[后缀数组详细整理]

    #35. 后缀排序 统计 描述 提交 自定义测试 这是一道模板题. 读入一个长度为 nn 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符 ...

  3. Uoj #35. 后缀排序(后缀数组)

    35. 后缀排序 统计 描述 提交 自定义测试 这是一道模板题. 读入一个长度为 nn 的由小写英文字母组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在 ...

  4. Codevs 1500 后缀排序(后缀数组)

    1500 后缀排序 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 天凯是MIT的新生.Prof. HandsomeG给了他一个 ...

  5. [洛谷P2127] 序列排序

    洛谷题目链接:序列排序 题目描述 小C有一个N个数的整数序列,这个序列的中的数两两不同.小C每次可以交换序列中的任意两个数,代价为这两个数之和.小C希望将整个序列升序排序,问小C需要的最小代价是多少? ...

  6. 洛谷P3809 后缀排序【后缀数组】【模板】

    题目背景 这是一道模板题. 题目描述 读入一个长度为 nn 的由大小写英文字母或数字组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置.位置编 ...

  7. 【后缀数组】洛谷P3809模板题

    题目背景 这是一道模板题. 题目描述 读入一个长度为 n n n 的由大小写英文字母或数字组成的字符串,请把这个字符串的所有非空后缀按字典序从小到大排序,然后按顺序输出后缀的第一个字符在原串中的位置. ...

  8. 洛谷P3809 后缀数组模板

    题目:https://www.luogu.org/problemnew/show/P3809 刚学了后缀数组,看人家手写演示了半天,大概明白了过程,但完全写不出来代码: 于是借鉴了许多,不过都差不多, ...

  9. 洛谷.3809.[模板]后缀排序(后缀数组 倍增) & 学习笔记

    题目链接 //输出ht见UOJ.35 #include<cstdio> #include<cstring> #include<algorithm> const in ...

随机推荐

  1. 当初希望自己是如何投入这个专业的学习的?曾经做过什么准备,或者立下过什么FLAG吗?

    学习好累,打游戏好爽  我不爱学习 认真勤勉投入学习 精心准备,刻苦学习 我的flag   作为大学生,需要了解今后职场社会,对职业方向有了进一步的认识.社会对于人才的要求在某些方面都是不谋而合的,比 ...

  2. ElasticSearch-The number of object passed must be even but was [1]-问题解决

    ES版本:6.4.3 1.The number of object passed must be even but was [1] 问题代码: IndexRequest indexRequest = ...

  3. 寒假day02-spring框架

    1 入门案例:IoC[掌握] 1.1 导入jar包 . 4 + 1  : 4个核心(beans.core.context.expression) + 1个依赖(commons-loggins...ja ...

  4. day61-mysql-索引原理和慢查询优化

    ProgramData是C盘隐藏的文件夹,mysql的data文件夹在里面,C:\ProgramData\MySQL\MySQL Server 8.0\Data 一.存储引擎 重点[面试题]: inn ...

  5. endnote插入|管理文件|成组

    信息检索 Endnote Filter(导入)---library(管理)---style(导出) 本地+网络数据库 点击research 在WOS上: 导入改文献: CNKI 导入PDF时选择PDF ...

  6. 小白学习之pytorch框架(2)-动手学深度学习(begin-random.shuffle()、torch.index_select()、nn.Module、nn.Sequential())

    在这向大家推荐一本书-花书-动手学深度学习pytorch版,原书用的深度学习框架是MXNet,这个框架经过Gluon重新再封装,使用风格非常接近pytorch,但是由于pytorch越来越火,个人又比 ...

  7. iOS个人中心渐变动画、微信对话框、标签选择器、自定义导航栏、短信验证输入框等源码

    iOS精选源码 简单的个人中心页面-自定义导航栏并予以渐变动画 程序员取悦女票的正确姿势---Tip1(iOS美容篇) iOS 前台重启应用和清除角标的问题 微信原生提醒对话框3.0 JHLikeBu ...

  8. postman测试

    Postman接口性能测试 1.从文件中获取参数,然后点击Runner 2.勾选测试用例,配置用例次数.参数文件.返回data等 3.点击run 测试用例 4.查看测试结果 5.测试接口:https: ...

  9. 14 微服务电商【黑马乐优商城】:day06-了解vue-router和webpack的使用

    本项目的笔记和资料的Download,请点击这一句话自行获取. day01-springboot(理论篇) :day01-springboot(实践篇) day02-springcloud(理论篇一) ...

  10. JDK8stream将list转Map对象报错java.lang.IllegalStateException

    ​ JDK8有很多新特性,比如lambda表达式,函数式编程以及stream流的使用,这几个新特性,使用过之后就爱不释手了,比如将list集合通过stream可以直接转换成map对象. 语法: Map ...