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

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

对于每个字符串,我们可以使用KMP算法来计算前缀函数数组。前缀函数数组的最后一个值p[len]可以帮助我们确定最大的重复子串的长度。如果p[len]不为0,那么这个长度就是最大的周期长度。重复次数就是整个字符串的长度除以周期长度。

KMP算法的步骤如下:

  • 初始化前缀函数数组p,长度为n+1,其中n是字符串的长度。
  • 遍历字符串,计算前缀函数数组中每个元素p[i]。
  • 计算周期长度为n - p[n]。
  • 如果n能被周期长度整除,那么重复次数就是n /周期长度;否则,重复次数为1。
  • 通过这种方法,我们可以高效地找到每个字符串最多能被重复连接的子串的数量。

    代码如下:

    #include 
    #include
    #include
    using namespace std;int main() { char s[10000005]; int len; scanf("%s", s + 1); len = strlen(s + 1); while (len != 1 || s[1] != '.') { int j = 0; for (int i = 2; i <= len; ++i) { while (j > 0 && s[i] != s[j + 1]) j = p[j]; if (s[i] == s[j + 1]) ++j; p[i] = j; } 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;}

    这个代码使用了KMP算法来计算前缀函数数组,从而确定最大的重复子串的周期长度和重复次数。通过这种方法,我们可以高效地解决问题,确保代码在处理长字符串时也能快速运行。

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

    你可能感兴趣的文章
    org.apache.xmlbeans.XmlOptions.setEntityExpansionLimit(I)Lorg/apache/xmlbeans/XmlOptions;
    查看>>
    org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
    查看>>
    org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:processDebugManifest'
    查看>>
    org.hibernate.HibernateException: Unable to get the default Bean Validation factory
    查看>>
    org.hibernate.ObjectNotFoundException: No row with the given identifier exists:
    查看>>
    org.springframework.amqp.AmqpConnectException:java.net.ConnectException:Connection timed out:connect
    查看>>
    org.springframework.beans.factory.BeanDefinitionStoreException
    查看>>
    org.springframework.boot.context.properties.ConfigurationBeanFactoryMetadata
    查看>>
    org.springframework.boot:spring boot maven plugin丢失---SpringCloud Alibaba_若依微服务框架改造_--工作笔记012
    查看>>
    SQL-CLR 类型映射 (LINQ to SQL)
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
    查看>>
    org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size exceeded
    查看>>
    org.tinygroup.serviceprocessor-服务处理器
    查看>>
    org/eclipse/jetty/server/Connector : Unsupported major.minor version 52.0
    查看>>
    org/hibernate/validator/internal/engine
    查看>>
    Orleans框架------基于Actor模型生成分布式Id
    查看>>
    SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
    查看>>
    ORM sqlachemy学习
    查看>>
    Ormlite数据库
    查看>>