?
簡單匹配算法
先來看一個簡單匹配算法的函數:
int Index_BF ( char S [ ], char T [ ], int pos )
{
/*
若串
S
中從第
pos(S
的下標
0
≤
pos<StrLength(S))
個字符
起存在和串
T
相同的子串,則稱匹配成功,返回第一個
這樣的子串在串
S
中的下標,否則返回
-1??? */
int i = pos, j = 0;
while ( S[i+j] != '\0'&& T[j] != '\0')
if ( S[i+j] == T[j] )
j ++;
//
繼續比較后一字符
else
{
i ++; j = 0;
//
重新開始新的一輪匹配
}
if ( T[j] == '\0')
return i;
//
匹配成功
??
返回下標
else
return -1;
//
串
S
中
(
第
pos
個字符起
)
不存在和串
T
相同的子串
}
// Index_BF
?