davidmou 发表于 2024-1-25 17:01:39

指定代码查找字符串

int StringFind(const char *pSrc, const char *pDst, int v_iStartPos)
{
    int i, j;
    for (i = v_iStartPos; pSrc!='\0'; i++)
    {
      if(pSrc!=pDst)
            continue;         
      j = 0;
      while(pDst !='\0' && pSrc!='\0')
      {
            j++;
            if(pDst!=pSrc)
            break;
      }
      if(pDst=='\0')
            return i;
    }
    return -1;
}
问一下指定代码的含义,逻辑,目的是什么

FishC 发表于 2024-1-25 17:03:19

这段代码是一个函数,名为StringFind。它的作用是在字符串pSrc中查找子串pDst,并返回子串在主串中的位置。

让我们逐行来解释一下这段代码的含义和逻辑:

int StringFind(const char *pSrc, const char *pDst, int v_iStartPos)
这句声明了一个函数StringFind,接收三个参数:pSrc(指向主串的指针),pDst(指向子串的指针),v_iStartPos(查找开始的位置)。

int i, j;
这里声明了两个整数变量i和j,用于迭代和计数。

for (i = v_iStartPos; pSrc!='\0'; i++)
这个for循环是用来遍历主串pSrc。循环从v_iStartPos开始,每次循环都会将i增加1,直到遇到主串的结束字符'\0'。

if(pSrc!=pDst)
    continue;
这个if语句用于比较主串当前位置的字符与子串第一个字符是否相等。如果不相等,则跳过本次循环,继续下一轮循环。

j = 0;
while(pDst !='\0' && pSrc!='\0')
{
    j++;
    if(pDst!=pSrc)
      break;
}
这个while循环用于匹配子串和主串中的字符。每次循环,j都会增加1,同时比较子串当前位置的字符和主串当前位置的字符是否相等。如果不相等,则跳出循环。

if(pDst=='\0')
    return i;
这个if语句用于判断是否匹配成功。当子串已经遍历到了结束字符'\0',说明匹配成功,返回当前位置i。

return -1;
如果上述的循环都完成了还没有返回,说明未找到匹配的子串,返回-1表示查找失败。

综上所述,这段代码的目的是在主串中查找子串,并返回子串在主串中的位置。但是这段代码有一些逻辑错误,在后续的while循环中,没有更新pSrc和pDst的指针,导致循环无法结束,因此无法正确匹配字符串。修复这个错误可以将while循环改为if语句,并在匹配成功后更新pSrc和pDst的指针位置。修复后的代码如下:

int StringFind(const char *pSrc, const char *pDst, int v_iStartPos)
{
    int i, j;
    for (i = v_iStartPos; pSrc != '\0'; i++)
    {
      if (pSrc != pDst)
            continue;

      j = 0;
      while (pDst != '\0' && pSrc != '\0')
      {
            if (pDst != pSrc)
                break;
            j++;
      }

      if (pDst == '\0')
            return i;
    }
    return -1;
}

这样,就可以正确地查找子串了。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: 指定代码查找字符串