博客
关于我
【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/

你可能感兴趣的文章
Linux下的系统监控与性能调优:从入门到精通
查看>>
LiveGBS user/save 逻辑缺陷漏洞复现(CNVD-2023-72138)
查看>>
localhost:5000在MacOS V12(蒙特利)中不可用
查看>>
logstash mysql 准实时同步到 elasticsearch
查看>>
Luogu2973:[USACO10HOL]赶小猪
查看>>
mabatis 中出现&lt; 以及&gt; 代表什么意思?
查看>>
Mac book pro打开docker出现The data couldn’t be read because it is missing
查看>>
MAC M1大数据0-1成神篇-25 hadoop高可用搭建
查看>>
mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
查看>>
Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
查看>>
MangoDB4.0版本的安装与配置
查看>>
Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
查看>>
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>