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

相关推荐
十月的皮皮25 分钟前
C语言学习笔记20260615-有序升序序列合并
c语言·笔记·学习
聚名网38 分钟前
域名net,com,cn有区别吗?有哪些不同呢?
服务器·开发语言·php
牛油果子哥q41 分钟前
STL set与map底层精讲,红黑树适配原理、有序去重特性、迭代器遍历、API实战与面试核心考点全解
开发语言·数据结构·c++·面试
foundbug99943 分钟前
直流电机 PID 速度控制 MATLAB 仿真程序
开发语言·matlab
Tian_Hang2 小时前
C++原型模式(Protype)
开发语言·c++·算法
天天讯通2 小时前
OKCC 呼叫中心安全性能全解析:技术防护与管理措施指南
大数据·开发语言·网络·人工智能·安全·语音识别
xufengzhu2 小时前
第三方 Python 库 redis-py + hiredis 的使用
开发语言·redis·python
jingling5553 小时前
go | 环境安装和快速入门
开发语言·后端·golang
yuan199973 小时前
欧拉梁静力与屈曲计算的 MATLAB 实现(有限差分法 + 解析解)
开发语言·算法·matlab
llxxyy卢3 小时前
polar夏季赛部分题目
开发语言·python