KMS算法

解题:http://hihocoder.com/problemset/problem/1015

KMP算法是一种改进的字符串匹配算法,由D.E.Knuth,J.H.Morris和V.R.Pratt同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法)。KMP算法的关键是利用匹配失败后的信息,尽量减少模式串与主串的匹配次数以达到快速匹配的目的。具体实现就是实现一个next()函数,函数本身包含了模式串的局部匹配信息。时间复杂度O(m+n)。

概念问题

主串S:就是比较长的那个字符串

模式串P:比较短的字符串

算法的功能:从比较长的字符串里面去找到比较短的字符串。

算法核心:

主串S: BBC ABCDAB ABCDABCDABDE

模式串P: ABCDABD

1)分析模式串

2)当匹配到不同的字符的时候去根据next数组去查找最多的移动距离  最多的移动距离是把P的起始位置移动到当期位置移动到上一个匹配数为0的元素。   :移动位数 = 已匹配的字符数 - 对应的部分匹配值

c++源码:

#include<iostream>
#include<stdlib.h>
#include<vector>
using namespace std;
inline void NEXT(const string&T,vector<int>&next){//按模式串生成vector,next(T.size())
   next[0]=-1;
   for(int i=1;i<T.size();i++){
      int j=next[i-1];
      while(T[i-1]!=T[j] &&j >=0) j=next[j];//递推计算
      if(T[i-1]==T[j]) next[i]=j+1;
      else next[i]=0;
   }
}
inline string::size_type COUNT_KMP(const string&S,const string&T){
//利用模式串T的next函数求T在主串S中的个数count的KMP算法
//其中T非空,
  vector<int>next(T.size());
  NEXT(T,next);
  string::size_type index,count=0;
  for(index=0;index<S.size();++index){
     int pos=0;
     string::size_type iter=index;
     while(pos<T.size()&&iter<S.size()){
        if(S[iter]==T[pos]){++iter;++pos;}
        else{
            if(pos==0) ++iter;
            else pos=next[pos-1]+1;
        }
      }
      if(pos==T.size() && (iter-index)==T.size()) ++count;
    }
    return count;
}

int main(int argc,char*argv[])
{
    string S;//="abaabcacabaabcacabaabcacabaabcacabaabcac";
    string T;//="ab";
    cin>>S;
    cin>>T;
    string::size_type count=COUNT_KMP(S,T);
    cout<<count<<endl;
    system("PAUSE");
    return 0;
}

  

时间: 2024-10-19 05:48:29

KMS算法的相关文章

基于Windows Server 2012 R2部署KMS服务器

基于Windows Server 2012 R2部署KMS服务器 关于Microsoft Windows / Microsoft Office "VLK" 和"MAK"两种激活的异同 "VLK"和"MAK"都是微软为"大客户"量身特定的激活方式.只要实施激活,就是永久激活."VLK"是Volume Licensing Key的缩写.微软对于"VLK"密钥施行"

python入门-分类和回归各种初级算法

引自:http://www.cnblogs.com/taichu/p/5251332.html ########################### #说明: # 撰写本文的原因是,笔者在研究博文"http://python.jobbole.com/83563/"中发现 # 原内容有少量笔误,并且对入门学友缺少一些信息.于是笔者做了增补,主要有: # 1.查询并简述了涉及的大部分算法: # 2.添加了连接或资源供进一步查询: # 3.增加了一些lib库的基本操作及说明: # 4.增加

【机器学习实战之三】:C++实现K-均值(K-Means)聚类算法

聚类是一种无监督的学习,它将相似的对象归到同一个簇中.它有点像全自动分类(类别体系是自动构建的).聚类方法几乎可以应用于所有对象,簇内的对象越相似,聚类的效果越好.本文要介绍一种称为K-均值(K-means)聚类的算法.之所以称之为K-均值是因为它可以发现k个不同的簇,且每个簇的中心采用簇中所含值的均值计算而成. 在介绍K-均值之前,先讨论一席簇识别(cluster identification).簇识别给出聚类结果的含义.假定有一些数据,现在将相似数据归到一起,簇识别会告诉我们这些簇到底都是些

微软的产品 比如Windows , office等激活的原理是什么? KMS等激活工具安全吗?

什么是密钥管理服务 (KMS)? 密钥管理服务 (KMS) 允许在本地网络上激活产品.这样,单台计算机不必连接至 Microsoft 便可激活产品.需要将一台计算机配置为 KMS 主机.管理员必须为 KMS 主机输入 KMS 主机密钥.必须激活 KMS 主机密钥并连接至 Microsoft 托管的服务器一次,才能激活. 默认情况下,已将 KMS 客户端密钥安装在 Microsoft Office 程序的批量版本中.通过使用 KMS 客户端密钥运行 Microsoft Office 批量版本的计算

经典排序算法 - 冒泡排序Bubble sort

 原文出自于 http://www.cnblogs.com/kkun/archive/2011/11/23/bubble_sort.html 经典排序算法 - 冒泡排序Bubble sort 原理是临近的数字两两进行比较,按照从小到大或者从大到小的顺序进行交换, 这样一趟过去后,最大或最小的数字被交换到了最后一位, 然后再从头开始进行两两比较交换,直到倒数第二位时结束,其余类似看例子 例子为从小到大排序, 原始待排序数组| 6 | 2 | 4 | 1 | 5 | 9 | 第一趟排序(外循环) 第

转载:DenseNet算法详解

原文连接:http://blog.csdn.net/u014380165/article/details/75142664 参考连接:http://blog.csdn.net/u012938704/article/details/53468483 本文这里仅当学习笔记使用,具体细节建议前往原文细度. 论文:Densely Connected Convolutional Networks 论文链接:https://arxiv.org/pdf/1608.06993.pdf 代码的github链接:h

基于位置信息的聚类算法介绍及模型选择

百度百科 聚类:将物理或抽象对象的集合分成由类似的对象组成的多个类的过程被称为聚类.由聚类所生成的簇是一组数据对象的集合,这些对象与同一个簇中的对象彼此相似,与其他簇中的对象相异."物以类聚,人以群分",在自然科学和社会科学中,存在着大量的分类问题.聚类分析又称群分析,它是研究(样品或指标)分类问题的一种统计分析方法.聚类分析起源于分类学,但是聚类不等于分类.聚类与分类的不同在于,聚类所要求划分的类是未知的. 分类和聚类算法一直以来都是数据挖掘,机器学习领域的热门课题,因此产生了众多的

密码算法详解——AES

0 AES简介 美国国家标准技术研究所在2001年发布了高级加密标准(AES).AES是一个对称分组密码算法,旨在取代DES成为广泛使用的标准. 根据使用的密码长度,AES最常见的有3种方案,用以适应不同的场景要求,分别是AES-128.AES-192和AES-256.本文主要对AES-128进行介绍,另外两种的思路基本一样,只是轮数会适当增加. 1 算法流程 AES加解密的流程图如下: AES加密过程涉及到4种操作:字节替代(SubBytes).行移位(ShiftRows).列混淆(MixCo

矩阵乘法的Strassen算法详解

题目描述 请编程实现矩阵乘法,并考虑当矩阵规模较大时的优化方法. 思路分析 根据wikipedia上的介绍:两个矩阵的乘法仅当第一个矩阵B的列数和另一个矩阵A的行数相等时才能定义.如A是m×n矩阵和B是n×p矩阵,它们的乘积AB是一个m×p矩阵,它的一个元素其中 1 ≤ i ≤ m, 1 ≤ j ≤ p. 值得一提的是,矩阵乘法满足结合律和分配率,但并不满足交换律,如下图所示的这个例子,两个矩阵交换相乘后,结果变了: 下面咱们来具体解决这个矩阵相乘的问题. 解法一.暴力解法 其实,通过前面的分析