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

你可能感兴趣的文章
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>