BF/KMF char储存十六进制
来源:互联网 发布:mac更新后部分变英文 编辑:程序博客网 时间:2024/06/08 08:29
#include <iostream>
#include <vector>
#include <map>
#include <string>
#include<fstream>
#include <stack>
#include <assert.h>
using namespace std;
char s[]=" ababcabcacbab";
char t[]=" abcac";
int BF (char s[],char t[])
{
//assert(s[0]);
//assert(t[0]);
int i=1;
int j=1;
while (i<=s[0]&&j<=t[0])
{
if(s[i]==t[j])
{
i++;
j++;
}
else
{
i=i-j+2;
j=1;
}
}
if(j>t[0])
return i-j+1;
else return 0;
}
void GetNext(char T[ ], int next[ ])
{ int j=0, k=-1;
next[0]=-1;
while(j<strlen(T)-1)
{
if (k==-1||T[j]==T[k])
{
j++;
k++;
next[j]=k;
}
else k=next[k];
}
}
int KMP(char S[],char T[])
{
int next[8],i=0,j=0,k=-1;
GetNext(T,next);
while (i<(int)strlen(S)&&j<(int)strlen (T))
{
if (j==-1||S[i]==T[j])
{
i++;j++;
}
else j=next[j];
}
for ( i=0;i<5;i++)
{
cout<<next[i];
}
if (j>=strlen(T))
return i-strlen(T);
else
return -1;
}
int main() {
s[0]=0x10;
t[0]=0x05;
char *S="ababcabaabcaabaababcaab",*T="abaababc";
int i,next[Maxsize];
cout << BF(s,t) << endl;
return 0;
}
- BF/KMF char储存十六进制
- kmf算法
- char十六进制字符并显示
- C#之KMF算法
- c/c++中 char与十六进制转换
- char *的十六进制字符串转化成long
- 十六进制字符串 char 数组 转换 c/c++
- C/C++ 十六进制char*与Binary char*相互转换
- java的char类型可以储存汉字吗
- char数组的赋值操作&动态储存建立删除
- Cstring char*、十六进制与十进制相互转化、ASCII=》中文
- 求教:char型字符串转换为十六进制整数问题
- 十六进制字符串 char数组 转换 c c++ java
- 十六进制字符串与char字节数组的转换函数
- 十六进制字符串与char字节数组的转换函数 II
- 十六进制字符串 char 数组 转换 c/c++/java
- 十六进制字符串、char数组的转换: c c++ java
- 十六进制字符串(CString或char[]) 和 BYTE,char数组 相互转化
- NMAP使用文档
- 数组有没有length()这个方法? String有没有length()这个方法?
- Exchange server 2013的改进概览
- myeclipse中导入js乱码的问题
- try {}里有一个return语句,那么紧跟在这个try后的finally {}里的code会不会被执行,什么时候被执行,在return前还是后?
- BF/KMF char储存十六进制
- 关于pager-taglib参数和其他url参数混合使用问题。
- 基于Javascript的队列和栈的实现
- 删除表空间
- 文本比较算法Ⅱ——Needleman/Wunsch算法
- 二叉树的建立和中序、先序、后序遍历
- 通过myeclipse启动tomcat
- error和exception有什么区别
- 求1000以内偶数的和