字符串操作之strstr()函數實現

strstr函數描述:

#include <string.h>
  size_t strspn( const char *str1, const char *str2 );

strstr()函數用來檢索子串在字符串中首次出現的位置。

這裏我自己實現strstr()函數。

#include <stdio.h>
#include <stdlib.h>
char *mystrstr(const char *pStr, const char *pV)
{
    if (pStr == NULL || pV == NULL)
    {
        return NULL;
    }
    int i = 0;
    int j = 0;
    for (i = 0; pStr[i] != '\0'; i++)
    {
        int tmp = i;//用tmp來記錄本輪i的位置
        j = 0;//每一輪都要把j置零
        while (pStr[i++] == pV[j++])
        {
            if (pV[j] == '\0')
            {
                return &pStr[tmp];//這個位置,一定是tmp,不是i,爲什麼?
            }
        }
        i = tmp;//用於將i重置爲while循環之前的值
    }
    return NULL;
}
int main()
{
    char *Pstr = "abcdefghijklmn";
    char *p = "jkl";
    char *p1 = mystrstr(Pstr, p);
    printf("%s\n", p1);
    system("pause");
    return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章