zoukankan      html  css  js  c++  java
  • HDU 3374 String Problem (KMP+最大最小表示)

    KMP,在有循环节的前提下: 循环节 t = len-next[len], 个数num = len/(len-next[len]);
    个人理解,如果有循环节,循环节长度必定小于等于len/2, 换句话说next[len]>=len/2;
    对于len%(len-next)!=0的这种情况不讨论,循环节不存在。
    下面是假设循环节存在的情况
    当次数等于2, 对于abcabc这种情况就不用说了,len = 6, next[len] = 3;
    当次数大于2,
    对于串a1 a2 a3 a4 a5 a6 a7 a8 a9
    如果有
    a1 a2 a3 a4 a5 a6 
             a4 a5 a6 a7 a8 a9
    next[len] = 6, len = 9;
     
    说明a7 a8 a9 = a4 a5 a6;
       a1 a2 a3 = a4 a5 a6;
    循环节就很明显了,其它情况也是类似与这样讨论。
    所以。。。。。
    view code

  • 相关阅读:
    Git学习1:Git起步
    [转载]AMOLED结构详解,BOE专家给你分析驱动补偿
    [C#] Microsoft .Net框架SerialPort类的用法与示例
    API 的历史
    AMOLED原理介紹
    [C#] SHA1校验函数用法
    示波器基本原理之三:存储深度
    示波器基本原理之二:采样率
    示波器基本原理之一:带宽
    数字转中文
  • 原文地址:https://www.cnblogs.com/zyx1314/p/3896582.html
Copyright © 2011-2022 走看看