C语言程序设计第四版(何钦铭、颜晖)第十一章指针进阶之查找子串

  1. 查找子串:输入两个字符串s和t,在字符串s中查找子串t,输出起始位置,若不存在,则输出-1。要求自定义函数char *search(char *s,char *t)返回子串t的首地址,若未找到,则返回NULL。试编写相应程序。

    #include <stdio.h>
    #include <stdlib.h>
    //朴素匹配算法
    char *search(char *s, char *t);

    int main()
    {
    // 测试示例
    char str1[] = "hello world";
    char str2[] = "world";
    char *result = search(str1, str2);

    复制代码
     if (result != NULL) {
         printf("找到子串,位置: %s\n", result);
     } else {
         printf("未找到子串\n");
     }
     
     return 0;

    }

    // 在字符串s中查找子串t,找到返回第一次出现的指针,否则返回NULL
    char *search(char *s, char *t) {
    // 处理特殊情况
    if (s == NULL || t == NULL || *t == '\0') {
    return s; // 空串总是匹配
    }

    复制代码
     char *sp, *tp, *start;
     
     // 遍历主字符串s
     for (sp = s; *sp != '\0'; sp++) {
         start = sp;  // 记录可能的匹配起始位置
         tp = t;      // 每次从子串开头开始比较
         
         // 逐个字符比较
         while (*sp != '\0' && *tp != '\0' && *sp == *tp) {
             sp++;
             tp++;
         }
         
         // 如果子串已遍历完,说明匹配成功
         if (*tp == '\0') {
             return start;
         }
         
         // 恢复sp到下一位置继续查找
         sp = start;
     }
     
     return NULL;  // 未找到

    }

输出结果:找到子串,位置: world

相关推荐
不吃香菜学java5 小时前
Redis的java客户端
java·开发语言·spring boot·redis·缓存
贵沫末5 小时前
python——打包自己的库并安装
开发语言·windows·python
文祐6 小时前
C++类之虚函数表及其内存布局(一个子类继承一个父类)
开发语言·c++
zuowei28896 小时前
华为网络设备配置文件备份与恢复(上传、下载、导出,导入)
开发语言·华为·php
xiaohe076 小时前
超详细 Python 爬虫指南
开发语言·爬虫·python
嗑嗑嗑瓜子的猫7 小时前
Java!它值得!
java·开发语言
xiaoshuaishuai87 小时前
C# GPU算力与管理
开发语言·windows·c#
lsx2024067 小时前
SVN 创建版本库
开发语言
xiaotao1317 小时前
01-编程基础与数学基石:Python错误与异常处理
开发语言·人工智能·python
glimix7 小时前
Word-Pop:使用C语言开发打单词游戏
c语言·游戏