关于一个字符串匹配算法

来源:百度知道 编辑:UC知道 时间:2024/05/27 11:54:37
毕业设计老师给了我们如下的一段代码,希望我们完成程序及优化,请高手指点!!
void RAITA(char *x, int m, char *y, int n) {
int j, bmBc[ASIZE];
char c, firstCh, *secondCh, middleCh, lastCh;

/* Preprocessing */
preBmBc(x, m, bmBc);
firstCh = x[0];
secondCh = x + 1;
middleCh = x[m/2];
lastCh = x[m - 1];

/* Searching */
j = 0;
while (j <= n - m) {
c = y[j + m - 1];
if (lastCh == c && middleCh == y[j + m/2] &&
firstCh == y[j] &&
memcmp(secondCh, y + j + 1, m - 2) == 0)
OUTPUT(j);
j += bmBc[c];
}
}
那两个函数老师是没有给,他给的全部我已经放在文体里面了,我不会怎么用C++编写这个程序,你能帮我编一个和这个原理一样的字符串匹配程序么?谢谢!!如果你能帮我,我还会追加100分!

我看了一下代码的,大概觉得它主要实现的功能是查找*y对应字符串中是否有与*x对应的字符串相等的子字符串存在,如果存在则返回该子串第一个字符在*y中的位置。
但是你没有把问题说清楚,比如preBmBc和memcmp这两个函数是在你给的程序中没有定义的,我猜了好久都不能猜出他们确切的用途。我估计你们老师主要也是叫你们实现这两个函数吧。。
如果你能在把问题给得详细的。。我可以继续帮你想想。。

不愧是毕业设计的题目啊,确实有点难度啊。我觉得那个函数不是一个简单的字符串匹配算法,它是一个多重字符串匹配算法。我给你个C语言的例子你参考一下吧。一下两下我也搞不出来了,真不好意思。
boyermoore算法的sample程序

TCHAR * BoyerMooreSearch(TCHAR *sSrc, TCHAR *sFind)
{
//
// 声明:
// 该段代码只是BoyerMoore(名字也许不准确)的基本思想,当
// 然不是最优的,具体完善工作就留给你自己乐!嘻嘻。
// 该算法的本质就是从字符串的右端而不是左端开始比较,这
// 样,当查询不匹配时才有可能直接跃过多个字符(最多可以跃过
// strlen(sFind)个字符),如果最右边的字符匹配则回溯。比如:
//
// pain
// ^ 这是第一次比较n和空格比
// The rain in SpainThe rain in Spain
//
// pain
// ^ 这是第二次比较,好爽呀!
// The rain in SpainThe rain in Spain
//
// 当然,这样比较会产生一些问题,比如:
//
// pain
// ^ (图1)
// The rain in SpainThe rain in Spain
//
// 如果比较到这儿,大家都会看到,只需再向后移到两个字符
// 就匹配成功了,但如果接下去还按上面