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

相关推荐
chao1898443 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
赏金术士3 小时前
Kotlin 习题集 · 高级篇
android·开发语言·kotlin
楼兰公子4 小时前
buildroot 在编译rust时裁剪平台类型数量的方法
开发语言·后端·rust
知识领航员4 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
吴声子夜歌4 小时前
Go——并发编程
开发语言·后端·golang
ooseabiscuit5 小时前
Laravel4.x:现代PHP框架的奠基之作
java·开发语言·php
c1s2d3n4cs5 小时前
Qt模仿nlohmann::json进行序列化和反序列化
开发语言·qt·json
AiTop1006 小时前
Claude Code 推出 Agent View:命令行编程正式进入“多线程并发“时代
开发语言·人工智能·ai·aigc
jf加菲猫6 小时前
第21章 Qt WebEngine
开发语言·c++·qt·ui
码农-阿杰7 小时前
深入理解 synchronized 底层实现:从 HotSpot C++ 源码看对象锁与 Monitor 机制
开发语言·c++·