博客
关于我
【KMP】重复子串
阅读量:697 次
发布时间:2019-03-14

本文共 862 字,大约阅读时间需要 2 分钟。

小目录

链接

题目描述

给定若干个的字符串,询问每个字符串最多是由多少个相同的子字符串重复连接而成的。

样例输入

abcdaaaaababab.

样例输出

143

思路

对于每一个字符串,我们可以用 k m p kmp kmp算法,求出 p p p值,则s串的第一位到第 p n p_n pn位和 n − p n n - p_n npn到第 n n n位都是匹配的,那如果 n   % ( n − p n ) = = 0 n\ \% (n - p_n) == 0 n %(npn)==0, 那就代表着存在重复子串,长度就为 n − p n n - p_n npn,个数为 n n − p n \frac{n}{n - p_n} npnn

代码

#include
#include
#include
#include
using namespace std;char s[10000005];int len, p[10000005];int main(){ scanf("%s", s + 1); len = strlen(s + 1); while(len != 1 || s[1] != '.') { len = strlen(s + 1); int j = 0; for(int i = 2; i <= len; ++i) { while(j && s[i] != s[j + 1]) j = p[j]; if(s[i] == s[j + 1]) ++j; p[i] = j; }//KMP算法 if(len % (len - p[len]) == 0) printf("%d\n", len / (len - p[len]));//判断 else printf("1\n"); scanf("%s", s + 1); len = strlen(s + 1); } return 0;}

转载地址:http://bbzlz.baihongyu.com/

你可能感兴趣的文章
Nginx映射本地json文件,配置解决浏览器跨域问题,提供前端get请求模拟数据
查看>>
nginx最最最详细教程来了
查看>>
Nginx服务器---正向代理
查看>>
Nginx服务器上安装SSL证书
查看>>
Nginx服务器的安装
查看>>
Nginx模块 ngx_http_limit_conn_module 限制连接数
查看>>
nginx添加模块与https支持
查看>>
Nginx用户认证
查看>>
Nginx的location匹配规则的关键问题详解
查看>>
Nginx的Rewrite正则表达式,匹配非某单词
查看>>
Nginx的使用总结(一)
查看>>
Nginx的使用总结(三)
查看>>
Nginx的使用总结(二)
查看>>
Nginx的可视化神器nginx-gui的下载配置和使用
查看>>
Nginx的是什么?干什么用的?
查看>>
Nginx访问控制_登陆权限的控制(http_auth_basic_module)
查看>>
nginx负载均衡和反相代理的配置
查看>>
nginx负载均衡器处理session共享的几种方法(转)
查看>>
nginx负载均衡的5种策略(转载)
查看>>
nginx负载均衡的五种算法
查看>>