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

相关推荐
应用市场2 小时前
王者荣耀式匹配系统深度解析:从 ELO 到 TrueSkill 的完整工程实现
开发语言·python
说实话起个名字真难啊2 小时前
前端JS审计:渗透测试的“破局之钥”
开发语言·前端·javascript·测试工具
xieliyu.2 小时前
Java、抽象类
java·开发语言
卷Java2 小时前
Python面向对象:class类与对象,3个案例讲透封装与继承
开发语言·python
计算机安禾2 小时前
【数据结构与算法】第13篇:栈(三):中缀表达式转后缀表达式及计算
c语言·开发语言·数据结构·c++·算法·链表
happymaker06262 小时前
servlet、jsp、请求转发、重定向的一些个人理解
java·开发语言·servlet
于先生吖2 小时前
国际版答题系统 JAVA 源码实战指南
java·开发语言
码界筑梦坊2 小时前
354-基于Python的全国水稻数据可视化分析系统
开发语言·python·信息可视化·数据分析·flask·bootstrap·毕业设计
码界筑梦坊2 小时前
336-基于Python的肺癌数据可视化分析预测系统
开发语言·python·信息可视化·数据分析·django·vue·毕业设计