c語(yǔ)言怎么查找字符串中子串位置

小億
368
2024-02-28 16:59:18

在C語(yǔ)言中,可以使用strstr函數(shù)來(lái)查找字符串中子串的位置。該函數(shù)的原型如下:

char *strstr(const char *haystack, const char *needle);

其中,haystack是要查找的字符串,needle是要查找的子串。函數(shù)返回子串在字符串中第一次出現(xiàn)的位置,如果找不到子串,則返回NULL。

下面是一個(gè)示例代碼:

#include <stdio.h>
#include <string.h>

int main() {
    const char *haystack = "Hello, World!";
    const char *needle = "World";
    
    char *result = strstr(haystack, needle);
    
    if (result) {
        printf("子串出現(xiàn)在字符串的位置:%ld\n", result - haystack);
    } else {
        printf("未找到子串\n");
    }
    
    return 0;
}

在上面的示例代碼中,我們查找子串"World"在字符串"Hello, World!“中的位置。如果找到子串,則打印子串在字符串中的位置,否則打印"未找到子串”。

0