求兩個字符串的最大公共字符串的長度

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;

}

相關文章
相關標籤/搜索