这题说的是给了一个模板串 然后又给了一个串 需要找出类似的按个模板串 , 改相等的位置要相等 该大于的位置到大于

我们将模板串做好失配指针就ok了,然后匹配和原来的匹配不同,这个匹配需要的是相对匹配,只要他们的相对位置相同就ok了,每次计算要插入的数在这个匹配中的排位

#include <iostream>
#include <cstdio>
#include <string.h>
#include <algorithm>
#include <vector>
#include <queue>
using namespace std;
const int maxn=;
int x[maxn],a[maxn],D[];
int F[maxn];
void getFail(int m)
{
F[]=; F[]=;
for(int i=; i<=m; i++)
{
int j=F[i];
while( j != && a[i] != a[j]) j = F[ j ];
F[i+]=( a[i] == a[j] )? j+ : ;
}
}
int perx[maxn][],pera[maxn][];
void init(int n, int m,int k)
{
memset(perx[],,sizeof(perx[]));
memset(pera[],,sizeof(pera[]));
for(int i=; i<=n; i++)
{
for(int j=; j<=k; j++)
perx[i][j]=perx[i-][j];
perx[i][ x[i] ]++;
}
for(int i=; i<=m; i++)
{
for(int j=; j<=k; j++)
pera[i][j]=pera[i-][j];
pera[i][a[i]]++;
}
}
bool vis[maxn];
bool jul(int xi, int aj)
{
int mii=,ei=,mij=,ej=;
for(int k=; k<x[xi]; k++)
mii+=perx[xi][k]-perx[xi-aj][k];
ei=perx[xi][ x[xi] ] - perx[ xi - aj ][ x[ xi ] ];
for(int k=; k<a[ aj ]; k++)
mij+=pera[ aj ][ k ];
ej=pera[ aj ][ a[aj] ];
return mii==mij&&ej==ei;
}
void find(int n,int m)
{
int j=;
for(int i=; i<=n; i++)
{
while(j!=&&jul(i,j)==false)j=F[j];
if(jul(i,j))j++;
if( j == m + )
{
vis[ i ]=true;j=F[j];
}
}
}
int main()
{
int n,m,k;
while(scanf("%d%d%d",&n,&m,&k)==)
{
memset(D,,sizeof(D));
for(int i=; i<=n; i++)
{
scanf("%d",&x[i]);
vis[i]=false;
}
for(int i=; i<=m; i++)
{
scanf("%d",&a[i]);
D[a[i]]=;
}
for(int i=; i<=k; i++)
D[i]=D[i]+D[i-];
for(int i=; i<=m; i++)
a[i]=D[a[i]];
getFail(m);
init(n,m,k);
find(n,m);
int ans=,loc=m;
while(loc<=n){
if(vis[loc]){
ans++;
loc+=m;
}else loc++;
}
printf("%d\n",ans);
}
return ;
}

hdu4749 kmp改进的更多相关文章

  1. hdu4749 kmp应用

    呃,从网上看的题解,然而其实有点地方还没搞懂,先放在这,以后再回来理解. 题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=4749 题目:2013 is ...

  2. 字符串匹配(BF算法和KMP算法及改进KMP算法)

    #include <stdio.h> #include <string.h> #include <stdlib.h> #include<cstring> ...

  3. c语言KMP匹配算法与字符串替换算法

    一.字符串匹配算法 (1)传统匹配算法BF int Index_BF(char* S, char* T){ int i=1,j=1; while(i<=strlen(S) && ...

  4. kpm字符串匹配算法

    首先是简单的朴素匹配算法 /* * 返回子串t在主串s的位置,若不存在则返回0 */ public static int index(String s, String t) { int i = 0;/ ...

  5. 大话数据结构(十二)java程序——KMP算法及改进的KMP算法实现

    1.朴素的模式匹配算法 朴素的模式匹配算法:就是对主串的每个字符作为子串开头,与要连接的字符串进行匹配.对主串做大循环,每个字符开头做T的长度的小循环,直到成功匹配或全部遍历完成为止. 又称BF算法 ...

  6. KMP及其改进算法

    本文主要讲述KMP已经KMP的一种改进方法.若发现不正确的地方,欢迎交流指出,谢谢! KMP算法的基本思想: KMP的算法流程: 每当一趟匹配过程中出现字符比较不等时,不需回溯 i 指针,而是利用已经 ...

  7. 【Java】 大话数据结构(8) 串的模式匹配算法(朴素、KMP、改进算法)

    本文根据<大话数据结构>一书,实现了Java版的串的朴素模式匹配算法.KMP模式匹配算法.KMP模式匹配算法的改进算法. 1.朴素的模式匹配算法 为主串和子串分别定义指针i,j. (1)当 ...

  8. 大话数据结构(8) 串的模式匹配算法(朴素、KMP、改进算法)

    --喜欢记得关注我哟[shoshana]-- 目录 1.朴素的模式匹配算法2.KMP模式匹配算法 2.1 KMP模式匹配算法的主体思路 2.2 next[]的定义与求解 2.3 KMP完整代码 2.4 ...

  9. KMP算法的改进

    KMP算法的改进 KMP算法已经在极大程度上提高了子符串的匹配效率,但是仍然有改进的余地. 1. 引入的情景 下面我们就其中的一种情况进行分析: 主串T为"aaaabcde-" 子 ...

随机推荐

  1. 下载JDK和Jmeter并设置系统环境变量

    一.JDK下载并设置系统环境变量 1.JDK官网下载地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html 点左边的 ...

  2. LeetCode 561 Array Partition I 解题报告

    题目要求 Given an array of 2n integers, your task is to group these integers into n pairs of integer, sa ...

  3. tomcat端口设置

    在tomcat安装目录下,编辑/conf/server.properties 更改对应的端口: 然后系统重启就可以了.

  4. 命令行安装kvm虚拟机、桥接网络、用virt-manager管理

    宿主机CentOS Linux release 7.2.1511 (Core),内核3.10.0-327.el7.x86_64 1.配置宿主机网络桥接 想让虚拟机有自己的ip且外网可访问,需要在安装虚 ...

  5. DMA驱动框架

    框架入口源文件:dma.c (可根据入口源文件,再按着框架到内核走一遍) 内核版本:linux_2.6.22.6    硬件平台:JZ2440 以下是驱动框架: 以下是驱动代码  dma.c : #i ...

  6. js正则表达式:学习网址和部分正则验证

    https://www.cnblogs.com/chenmeng0818/p/6370819.html ① 不以0开头的多个数字,但可以是单个0,必须为数字,位数不允许超过10个. var reg=/ ...

  7. 'react-scripts' is not recognized as an internal or external command

    React项目在执行npm start的时候报下面的错误: 解决办法:把项目目录中node_modules文件夹删掉,重新npm install一下,然后再执行npm start

  8. finecms设置伪静态后分享到微信不能访问怎么处理

    finecms设置伪静态后分享到微信不能访问,分享的链接自动增加了一串参数,类似这样的***.html?from=singlemessage&isappinstalled=0,刚开始ytkah ...

  9. 工具篇-Mac上搭建本地svn服务器以及使用Cornerstone进行本地版本控制

    1.在桌面上见一个文件夹命名为svn,然后打开终端: 创建一个mycode仓库:svnadmin create /Users/gaoyizhen736(自己的mac的用户名)/Desktop/svn/ ...

  10. html与js和php之间实现数据交互

    <div class="top3"> <input id="KeyWord" type="text" class=&quo ...