int getCommonStrLength(char * pFirstStr, char * pSecondStr)get
{co
if (pFirstStr == NULL || NULL == pSecondStr) return 0; 字符
int i, len1, len2, len, s1_start, s2_start, idx, curmax, max;return
len1 = strlen(pFirstStr); tar
len2 = strlen(pSecondStr);
len = len1 + len2;
max = 0;
for (i = 0; i < len; i++)
{
s1_start = s2_start = 0;
if (i < len1)
s1_start = len1 - i; //每次開始匹配的起始位置
else
s2_start = i - len1;
curmax = 0;
for (idx = 0; (s1_start + idx < len1) && (s2_start + idx < len2); idx++)
{
if (toupper(pFirstStr[s1_start + idx]) == toupper(pSecondStr[s2_start + idx]))
curmax++;
else //只要有一個不相等,就說明相等的公共字符斷了,不連續了,要保存curmax與max中的最大值,並將curmax重置爲0
{
max = curmax > max ? curmax : max;
curmax = 0;
}
}
max = curmax > max ? curmax : max;
}
return max;
}