当前位置: 首页 > news >正文

C语言之strstr函数的使用和模拟实现

C语言之strstr函数的模拟实现

文章目录

  • C语言之strstr函数的模拟实现
    • 1. strstr函数的介绍
    • 2. strstr函数的使用
    • 3. strstr的模拟实现
      • 3.1 实现思路
      • 3.2 实现代码

1. strstr函数的介绍

函数声明如下:

char * strstr ( const char * str1, const char * str2 );    

strstr函数是用于在字符串str1中找str2字符串第一次出现的位置,如果找到改位置,则将这个位置返回,找不到则返回一个空指针NULL
strstr函数比较元素时,不包含 \0,以 \0 作为结束的标志

2. strstr函数的使用

#include <stdio.h>
#include <string.h>int main()
{char arr1[] = "abcadefdef";char arr2[] = "def";char * ret = strstr(arr1, arr2);if (ret != NULL){printf("%s\n", ret);}else{printf("找不到\n");}return 0;
}

如果arr1字符串中是否有arr2 def 这三个字符,必须得是连续的
然后用ret来接收strstr函数的返回值
如果arr1中有出现arr2这个字符串,则返回第一次出现的地址
否则则返回一个空指针
最后继续判断是否为空指针,如果不是则打印第一次出现的位置

运行结果如下:
在这里插入图片描述

3. strstr的模拟实现

3.1 实现思路

假设有两个字符数组
str1中的字符串为 a b b b c d e f \0
str2中的字符串为 b b c \0
在这里插入图片描述

当将这两个字符串传给strstr函数时,传入的是首元素地址,所以str1指向字符 a ,str2指向字符 b

  1. 要判断str1字符串中是否有str2字符串,首先,str1要从第一个元素开始比较,如果从第一个元素就错了,所以要通过指针偏移的方式来找到第二个元素,如果两个元素相同,那么str1 和 str2 都偏移一个字节找到下一对要比较的元素

  2. 当指针偏移到第二个元素的时候,当第二遍比较的时候,str1 和 str2 前两个字符都相同,此时str1指向第三个元素 b ,str2指向第二个元素 b ,然后str1 和 str2 都偏移一个字节找到下一个元素, str1 找到第四个元素 b,str2 找到第三个元素 c,此时两个元素不相同,str1 得回到比较时的位置,str2 得回到起始位置

3.所以我们可以定义两个指针变量用来记录str1比较时的位置,和str2的起始位置,假设为s1 和 s2
在这里插入图片描述

通过比较s1 和 s2 的元素,判断是否相符合,如果不符合s1 回到 str1的位置, s2回到 str2 的位置
然后str1++找到下一个元素,从这个元素开始比较,当s2指向\0的时候,则返回str1的地址,我们也可以定义一个cur来存放str1的地址,这样比较清晰一点

3.2 实现代码

#include <stdio.h>
#include <string.h>
#include <assert.h>char* my_strstr(const char* str1, const char* str2)
{const char* cur = str1;  //用cur用来记录当前的位置const char* s1 = NULL;   //通过s1 和 s2 比较元素const char* s2 = NULL;assert(str1 && str2);    //assert断言,如果传入的地址有有一个会空指针,则直接返回str1的地址if (str2 == '\0')return (char*)str1;while (*cur)   //当cur中的值不为'\0'时,进入循环{s1 = cur;   //s1回到比较时的位置s2 = str2;  //s2回到初始位置while (*s1 == *s2) //当s1和s2指向的值相等时,进入循环{s1++;  //找到下一个元素s2++;  //找到下一个元素//再次比较}if (*s2 == '\0')  //当s2中的元素为'\0'时,则说明在str1中找到了str2return (char*)cur; //返回当前的位置cur++; //第一次没找到,找到下一个元素重新寻找}return NULL; //如果在循环中没有找到,则返回一个空指针
}int main()
{char arr1[] = "abcadefdef";char arr2[] = "def";char* ret = my_strstr(arr1, arr2);if (ret != NULL){printf("%s\n", ret);}else{printf("找不到\n");}return 0;
}

运行结果如下:
在这里插入图片描述

http://www.lryc.cn/news/242045.html

相关文章:

  • 【间歇振荡器2片555时基仿真】2022-9-24
  • MySQL与PostgreSQL 的一些SQL
  • Spring 七大组件
  • 【UGUI】实现跑酷游戏分数血量显示在UI中
  • Vue和React对比
  • iPhone的实时照片不能直接查看,但有不少替代方法可以查看
  • 弹窗msvcp140_1.dll丢失的解决方法,超简单的方法分享
  • 人工智能基础_机器学习047_用逻辑回归实现二分类以上的多分类_手写代码实现逻辑回归OVR概率计算---人工智能工作笔记0087
  • Interactive Visual Data Analysis
  • Prometheus监控mysql nginx tomcat 黑盒监控
  • Altium Designer学习笔记12
  • csrf跨站请求伪造详解
  • GitLab的个人仓库转移到团队仓库
  • Linux:Ubuntu实现远程登陆
  • Unity中Shader的Standard材质解析(二)
  • 【Python 训练营】N_5 斐波那契数列
  • x-www-form-urlencoded的含义解释,getReader()和getParameter()的区别
  • python每日一题——3最长连续序列
  • 什么?Postman也能测WebSocket接口了?
  • requests库的学习(详细篇)
  • postgreSQL如何快速查询大表数据量
  • 微信小程序内嵌h5页面,实现动态设置顶部标题的功能
  • 手机IP地址会随位置变化吗
  • 为什么考完软考中级还要考高级呢?
  • 03.实现
  • 可视化大屏时代的到来:智慧城市管理的新思路
  • Hibernate的三种状态
  • React 中 useContext 的用法与性能问题详解
  • 流程图是什么,用什么软件做?
  • Linux 家目录和根目录