strstr!!!

`strstr` 是 C 语言中的一个标准库函数,用于在一个字符串中查找子串。它的原型定义在 `string.h` 头文件中。`strstr` 函数

返回指向子串首次出现位置的指针,如果未找到子串,则返回 `NULL`。

函数原型

```c

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

```

**参数**:

  • `haystack`:要搜索的源字符串。

  • `needle`:要在 `haystack` 中搜索的子串。

**返回值**:

  • 返回一个指向 `haystack` 中 `needle` 第一次出现位置的指针。

  • 如果 `needle` 是空字符串,`strstr` 返回 `haystack` 的指针。

  • 如果 `needle` 未在 `haystack` 中找到,返回 `NULL`。

示例

下面是一个使用 `strstr` 的示例程序,演示了如何在一个字符串中查找子串:

复制代码
#include <stdio.h>
#include <string.h>

int main() {
    char str[] = "Hello, World! This is a test string.";
    char substr1[] = "World";
    char substr2[] = "test";
    char substr3[] = "example";

    // 查找子串 "World"
    char *ptr1 = strstr(str, substr1);
    if (ptr1 != NULL) {
        printf("Found '%s' in string at position %ld\n", substr1, ptr1 - str);
    } else {
        printf("'%s' not found in string\n", substr1);
    }

    // 查找子串 "test"
    char *ptr2 = strstr(str, substr2);
    if (ptr2 != NULL) {
        printf("Found '%s' in string at position %ld\n", substr2, ptr2 - str);
    } else {
        printf("'%s' not found in string\n", substr2);
    }

    // 查找子串 "example"
    char *ptr3 = strstr(str, substr3);
    if (ptr3 != NULL) {
        printf("Found '%s' in string at position %ld\n", substr3, ptr3 - str);
    } else {
        printf("'%s' not found in string\n", substr3);
    }

    return 0;
}

输出

复制代码
Found 'World' in string at position 7
Found 'test' in string at position 19
'example' not found in string

解释

  1. **查找 "World"**:
  • `strstr(str, substr1)` 返回指向 `str` 中 `"World"` 首次出现位置的指针。

  • `ptr1 - str` 计算 `"World"` 在 `str` 中的起始位置。

  1. **查找 "test"**:
  • `strstr(str, substr2)` 返回指向 `str` 中 `"test"` 首次出现位置的指针。

  • `ptr2 - str` 计算 `"test"` 在 `str` 中的起始位置。

  1. **查找 "example"**:
  • `strstr(str, substr3)` 未找到 `"example"`,返回 `NULL`。

这个示例展示了如何使用 `strstr` 函数在一个字符串中查找子串,并输出子串的位置或未找到的信息。

相关推荐
CoderCodingNo20 小时前
【GESP】C++五级/四级练习(双指针/数学) luogu-P1147 连续自然数和
开发语言·c++·算法
颜酱20 小时前
前端算法必备:双指针从入门到很熟练(快慢指针+相向指针+滑动窗口)
前端·后端·算法
Wect20 小时前
LeetCode 274. H 指数:两种高效解法全解析
算法·typescript
Q741_14720 小时前
海致星图招聘 数据库内核研发实习生 一轮笔试 总结复盘(2) 作答语言:C/C++ 哈夫曼编码 LRU
c语言·数据库·c++·算法·笔试·哈夫曼编码·哈夫曼树
Hello.Reader20 小时前
PyFlink DataStream Operators 算子分类、函数写法、类型系统、链路优化(Chaining)与工程化踩坑
前端·python·算法
hweiyu0020 小时前
最短路径算法:Floyd-Warshall算法
算法
荒诞硬汉20 小时前
数组常见算法
java·数据结构·算法
少许极端20 小时前
算法奇妙屋(二十四)-二维费用的背包问题、似包非包问题、卡特兰数问题(动态规划)
算法·动态规划·卡特兰数·二维费用背包·似包非包
Z1Jxxx21 小时前
日期日期日期
开发语言·c++·算法
万行21 小时前
机器学习&第五章生成式生成器
人工智能·python·算法·机器学习