鱼C论坛

 找回密码
 立即注册
查看: 396|回复: 1

指定代码查找字符串

[复制链接]
发表于 2024-1-25 17:01:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
int StringFind(const char *pSrc, const char *pDst, int v_iStartPos)  
{  
    int i, j;  
    for (i = v_iStartPos; pSrc[i]!='\0'; i++)  
    {  
        if(pSrc[i]!=pDst[0])  
            continue;         
        j = 0;  
        while(pDst[j] !='\0' && pSrc[i+j]!='\0')  
        {  
            j++;  
            if(pDst[j]!=pSrc[i+j])  
            break;  
        }  
        if(pDst[j]=='\0')  
            return i;  
    }  
    return -1;  
}
问一下指定代码的含义,逻辑,目的是什么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-1-25 17:03:19 | 显示全部楼层
这段代码是一个函数,名为StringFind。它的作用是在字符串pSrc中查找子串pDst,并返回子串在主串中的位置。

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

  1. int StringFind(const char *pSrc, const char *pDst, int v_iStartPos)
复制代码

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

  1. int i, j;
复制代码

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

  1. for (i = v_iStartPos; pSrc!='\0'; i++)
复制代码

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

  1. if(pSrc!=pDst)
  2.     continue;
复制代码

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

  1. j = 0;
  2. while(pDst !='\0' && pSrc!='\0')
  3. {
  4.     j++;
  5.     if(pDst!=pSrc)
  6.         break;
  7. }
复制代码

这个while循环用于匹配子串和主串中的字符。每次循环,j都会增加1,同时比较子串当前位置的字符和主串当前位置的字符是否相等。如果不相等,则跳出循环。

  1. if(pDst=='\0')
  2.     return i;
复制代码

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

  1. return -1;
复制代码

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

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

  1. int StringFind(const char *pSrc, const char *pDst, int v_iStartPos)
  2. {
  3.     int i, j;
  4.     for (i = v_iStartPos; pSrc[i] != '\0'; i++)
  5.     {
  6.         if (pSrc[i] != pDst[0])
  7.             continue;

  8.         j = 0;
  9.         while (pDst[j] != '\0' && pSrc[i + j] != '\0')
  10.         {
  11.             if (pDst[j] != pSrc[i + j])
  12.                 break;
  13.             j++;
  14.         }

  15.         if (pDst[j] == '\0')
  16.             return i;
  17.     }
  18.     return -1;
  19. }
复制代码


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

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-20 18:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表