【链接】h在这里写链接


【题意】


接上一篇文章

【题解】


一个字符串所有不同的子串的个数=∑(len-sa[i]-height[i])

【错的次数】


0

【反思】


在这了写反思

【代码】

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3.  
  4. const int N = 2e3;
  5. const int MAX_CHAR = 300;//每个数字的最大值。
  6. char s[N + 10];//如果是数字,就写成int s[N+10]就好,从0开始存
  7. int Sa[N + 10], T1[N + 10], T2[N + 10], C[N + 10];
  8. int Height[N + 10], Rank[N + 10];
  9.  
  10. void build_Sa(int n, int m) {
  11. int i, *x = T1, *y = T2;
  12. for (i = 0; i<m; i++) C[i] = 0;
  13. for (i = 0; i<n; i++) C[x[i] = s[i]]++;
  14. for (i = 1; i<m; i++) C[i] += C[i - 1];
  15. for (i = n - 1; i >= 0; i--) Sa[--C[x[i]]] = i;
  16. for (int k = 1; k <= n; k <<= 1)
  17. {
  18. int p = 0;
  19. for (i = n - k; i<n; i++) y[p++] = i;
  20. for (i = 0; i<n; i++) if (Sa[i] >= k) y[p++] = Sa[i] - k;
  21. for (i = 0; i<m; i++) C[i] = 0;
  22. for (i = 0; i<n; i++) C[x[y[i]]]++;
  23. for (i = 1; i<m; i++) C[i] += C[i - 1];
  24. for (i = n - 1; i >= 0; i--) Sa[--C[x[y[i]]]] = y[i];
  25. swap(x, y);
  26. p = 1; x[Sa[0]] = 0;
  27. for (i = 1; i<n; i++)
  28. x[Sa[i]] = y[Sa[i - 1]] == y[Sa[i]] && y[Sa[i - 1] + k] == y[Sa[i] + k] ? p - 1 : p++;
  29. if (p >= n) break;
  30. m = p;
  31. }
  32. }
  33.  
  34. void getHeight(int n)
  35. {
  36. int i, j, k = 0;
  37. for (i = 1; i <= n; i++) Rank[Sa[i]] = i;
  38. for (i = 0; i<n; i++) {
  39. if (k) k--;
  40. j = Sa[Rank[i] - 1];
  41. while (s[i + k] == s[j + k]) k++;
  42. Height[Rank[i]] = k;
  43. }
  44. }
  45.  
  46. int bo[300];
  47.  
  48. int main() {
  49. //freopen("F:\\rush.txt", "r", stdin);
  50. int T;
  51. scanf("%d", &T);
  52. while (T--)
  53. {
  54. scanf("%s", s);
  55. int n = strlen(s), tn = n;
  56. s[n] = 0;
  57. build_Sa(n + 1, MAX_CHAR);//注意调用n+1
  58. getHeight(n);
  59. int ans = 0;
  60. for (int i = 1; i <= n; i++)
  61. ans += (n - Height[i] - Sa[i]);
  62. printf("%d\n", ans);
  63. }
  64. return 0;
  65. }

【SPOJ 694】Distinct Substrings (更直接的求法)的更多相关文章

  1. SPOJ 694. Distinct Substrings (后缀数组不相同的子串的个数)转

    694. Distinct Substrings Problem code: DISUBSTR   Given a string, we need to find the total number o ...

  2. SPOJ 694 Distinct Substrings

    Distinct Substrings Time Limit: 1000ms Memory Limit: 262144KB This problem will be judged on SPOJ. O ...

  3. SPOJ 694 Distinct Substrings/SPOJ 705 New Distinct Substrings(后缀数组)

    Given a string, we need to find the total number of its distinct substrings. Input T- number of test ...

  4. spoj 694. Distinct Substrings 后缀数组求不同子串的个数

    题目链接:http://www.spoj.com/problems/DISUBSTR/ 思路: 每个子串一定是某个后缀的前缀,那么原问题等价于求所有后缀之间的不相同的前缀的个数.如果所有的后缀按照su ...

  5. 后缀数组 SPOJ 694 Distinct Substrings

    题目链接 题意:给定一个字符串,求不相同的子串的个数 分析:我们能知道后缀之间相同的前缀的长度,如果所有的后缀按照 suffix(sa[0]), suffix(sa[1]), suffix(sa[2] ...

  6. SPOJ 694 Distinct Substrings(不相同子串个数)

    https://vjudge.net/problem/SPOJ-DISUBSTR 题意: 给定一个字符串,求不相同的子串的个数. 思路: #include<iostream> #inclu ...

  7. 【SPOJ】Distinct Substrings(后缀自动机)

    [SPOJ]Distinct Substrings(后缀自动机) 题面 Vjudge 题意:求一个串的不同子串的数量 题解 对于这个串构建后缀自动机之后 我们知道每个串出现的次数就是\(right/e ...

  8. 【SPOJ】Distinct Substrings/New Distinct Substrings(后缀数组)

    [SPOJ]Distinct Substrings/New Distinct Substrings(后缀数组) 题面 Vjudge1 Vjudge2 题解 要求的是串的不同的子串个数 两道一模一样的题 ...

  9. 【SPOJ】Distinct Substrings

    [SPOJ]Distinct Substrings 求不同子串数量 统计每个点有效的字符串数量(第一次出现的) \(\sum\limits_{now=1}^{nod}now.longest-paren ...

随机推荐

  1. js关于循环的理解

    学习任何语言都离不开循环,js也是一样,看了网上的资料,整理一份关于js循环的理解. 1.最基础循环,js和其他高级语言一样使用for.while循环 (function() { for(var i= ...

  2. linux系统常用日志

    系统日志记录着系统运行中的记录信息,在服务或者系统发生故障的时候,通过查询系统日志,可以帮助我们诊断.系统日志可以预警安全问题,系统日志一般都存放在/var/log目录下 /var/log/dmesg ...

  3. 爬虫爬数据时,post数据乱码解决的方法

    近期在写一个爬虫,目标站点是:http://zx.bjmemc.com.cn/.可能是为了防止被爬取数据,它给自身数据加了密. 用谷歌自带的抓包工具也不能捕获到数据. 于是下了Fiddler.     ...

  4. screen-调节屏幕亮度

    今天做项目的时候,需要实现一个功能,就是进入一个应用,在这个应用中,屏幕的亮度变为最亮.关键代码如下 bt1.setOnClickListener(new OnClickListener() { @O ...

  5. Java学习笔记五 常用API对象一

    常用API:字符串操作:String类,StringBuffer类,StringBulider类 字符串是最重要的数据类型之一,处理字符串也是一种语言的基本工作. 1.String类: public ...

  6. 新手前端笔记之--初识css

    css样式表是为了容纳与html文档分离出来的样式属性而产生的,所以她理所当然的包含两个部分:1.样式的表示,使用{属性1:属性值:属性2:属性值:...},2.样式与标签的对应(如何找的对应标签), ...

  7. Office GVLK 密钥对照表(kms激活专用)

    Office2016系列: Office Professional Plus 2016:XQNVK-8JYDB-WJ9W3-YJ8YR-WFG99 Office Standard 2016:JNRGM ...

  8. BZOJ2631: tree(LCT)

    Description 一棵n个点的树,每个点的初始权值为1.对于这棵树有q个操作,每个操作为以下四种操作之一: + u v c:将u到v的路径上的点的权值都加上自然数c: - u1 v1 u2 v2 ...

  9. python3操作Excel

    1.安装openpyxl模块: 在cmd命令窗执行命令 pip install openpyxl    安装openpyxl模块 from openpyxl import load_workbook ...

  10. Quartz学习总结(1)——Spring集成Quartz框架

    一.Quartz简介 Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用.Quartz可以用来创建简 ...