【SPOJ 694】Distinct Substrings (更直接的求法)
【链接】h在这里写链接
【题意】
【题解】
【错的次数】
【反思】
【代码】
- #include<bits/stdc++.h>
- using namespace std;
- const int N = 2e3;
- const int MAX_CHAR = 300;//每个数字的最大值。
- char s[N + 10];//如果是数字,就写成int s[N+10]就好,从0开始存
- int Sa[N + 10], T1[N + 10], T2[N + 10], C[N + 10];
- int Height[N + 10], Rank[N + 10];
- void build_Sa(int n, int m) {
- int i, *x = T1, *y = T2;
- for (i = 0; i<m; i++) C[i] = 0;
- for (i = 0; i<n; i++) C[x[i] = s[i]]++;
- for (i = 1; i<m; i++) C[i] += C[i - 1];
- for (i = n - 1; i >= 0; i--) Sa[--C[x[i]]] = i;
- for (int k = 1; k <= n; k <<= 1)
- {
- int p = 0;
- for (i = n - k; i<n; i++) y[p++] = i;
- for (i = 0; i<n; i++) if (Sa[i] >= k) y[p++] = Sa[i] - k;
- for (i = 0; i<m; i++) C[i] = 0;
- for (i = 0; i<n; i++) C[x[y[i]]]++;
- for (i = 1; i<m; i++) C[i] += C[i - 1];
- for (i = n - 1; i >= 0; i--) Sa[--C[x[y[i]]]] = y[i];
- swap(x, y);
- p = 1; x[Sa[0]] = 0;
- for (i = 1; i<n; i++)
- x[Sa[i]] = y[Sa[i - 1]] == y[Sa[i]] && y[Sa[i - 1] + k] == y[Sa[i] + k] ? p - 1 : p++;
- if (p >= n) break;
- m = p;
- }
- }
- void getHeight(int n)
- {
- int i, j, k = 0;
- for (i = 1; i <= n; i++) Rank[Sa[i]] = i;
- for (i = 0; i<n; i++) {
- if (k) k--;
- j = Sa[Rank[i] - 1];
- while (s[i + k] == s[j + k]) k++;
- Height[Rank[i]] = k;
- }
- }
- int bo[300];
- int main() {
- //freopen("F:\\rush.txt", "r", stdin);
- int T;
- scanf("%d", &T);
- while (T--)
- {
- scanf("%s", s);
- int n = strlen(s), tn = n;
- s[n] = 0;
- build_Sa(n + 1, MAX_CHAR);//注意调用n+1
- getHeight(n);
- int ans = 0;
- for (int i = 1; i <= n; i++)
- ans += (n - Height[i] - Sa[i]);
- printf("%d\n", ans);
- }
- return 0;
- }
【SPOJ 694】Distinct Substrings (更直接的求法)的更多相关文章
- SPOJ 694. Distinct Substrings (后缀数组不相同的子串的个数)转
694. Distinct Substrings Problem code: DISUBSTR Given a string, we need to find the total number o ...
- SPOJ 694 Distinct Substrings
Distinct Substrings Time Limit: 1000ms Memory Limit: 262144KB This problem will be judged on SPOJ. O ...
- 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 ...
- spoj 694. Distinct Substrings 后缀数组求不同子串的个数
题目链接:http://www.spoj.com/problems/DISUBSTR/ 思路: 每个子串一定是某个后缀的前缀,那么原问题等价于求所有后缀之间的不相同的前缀的个数.如果所有的后缀按照su ...
- 后缀数组 SPOJ 694 Distinct Substrings
题目链接 题意:给定一个字符串,求不相同的子串的个数 分析:我们能知道后缀之间相同的前缀的长度,如果所有的后缀按照 suffix(sa[0]), suffix(sa[1]), suffix(sa[2] ...
- SPOJ 694 Distinct Substrings(不相同子串个数)
https://vjudge.net/problem/SPOJ-DISUBSTR 题意: 给定一个字符串,求不相同的子串的个数. 思路: #include<iostream> #inclu ...
- 【SPOJ】Distinct Substrings(后缀自动机)
[SPOJ]Distinct Substrings(后缀自动机) 题面 Vjudge 题意:求一个串的不同子串的数量 题解 对于这个串构建后缀自动机之后 我们知道每个串出现的次数就是\(right/e ...
- 【SPOJ】Distinct Substrings/New Distinct Substrings(后缀数组)
[SPOJ]Distinct Substrings/New Distinct Substrings(后缀数组) 题面 Vjudge1 Vjudge2 题解 要求的是串的不同的子串个数 两道一模一样的题 ...
- 【SPOJ】Distinct Substrings
[SPOJ]Distinct Substrings 求不同子串数量 统计每个点有效的字符串数量(第一次出现的) \(\sum\limits_{now=1}^{nod}now.longest-paren ...
随机推荐
- js关于循环的理解
学习任何语言都离不开循环,js也是一样,看了网上的资料,整理一份关于js循环的理解. 1.最基础循环,js和其他高级语言一样使用for.while循环 (function() { for(var i= ...
- linux系统常用日志
系统日志记录着系统运行中的记录信息,在服务或者系统发生故障的时候,通过查询系统日志,可以帮助我们诊断.系统日志可以预警安全问题,系统日志一般都存放在/var/log目录下 /var/log/dmesg ...
- 爬虫爬数据时,post数据乱码解决的方法
近期在写一个爬虫,目标站点是:http://zx.bjmemc.com.cn/.可能是为了防止被爬取数据,它给自身数据加了密. 用谷歌自带的抓包工具也不能捕获到数据. 于是下了Fiddler. ...
- screen-调节屏幕亮度
今天做项目的时候,需要实现一个功能,就是进入一个应用,在这个应用中,屏幕的亮度变为最亮.关键代码如下 bt1.setOnClickListener(new OnClickListener() { @O ...
- Java学习笔记五 常用API对象一
常用API:字符串操作:String类,StringBuffer类,StringBulider类 字符串是最重要的数据类型之一,处理字符串也是一种语言的基本工作. 1.String类: public ...
- 新手前端笔记之--初识css
css样式表是为了容纳与html文档分离出来的样式属性而产生的,所以她理所当然的包含两个部分:1.样式的表示,使用{属性1:属性值:属性2:属性值:...},2.样式与标签的对应(如何找的对应标签), ...
- Office GVLK 密钥对照表(kms激活专用)
Office2016系列: Office Professional Plus 2016:XQNVK-8JYDB-WJ9W3-YJ8YR-WFG99 Office Standard 2016:JNRGM ...
- BZOJ2631: tree(LCT)
Description 一棵n个点的树,每个点的初始权值为1.对于这棵树有q个操作,每个操作为以下四种操作之一: + u v c:将u到v的路径上的点的权值都加上自然数c: - u1 v1 u2 v2 ...
- python3操作Excel
1.安装openpyxl模块: 在cmd命令窗执行命令 pip install openpyxl 安装openpyxl模块 from openpyxl import load_workbook ...
- Quartz学习总结(1)——Spring集成Quartz框架
一.Quartz简介 Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用.Quartz可以用来创建简 ...