码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【C语言】模拟实现strstr


    strstr这个库函数看到这个名字大概率猜不到这是什么函数,
    但经过学习就可以很好的认识到这个函数

    目录

    • 介绍:
    • 模拟实现:
      • 思路:
      • 代码实现:

    介绍:

    在这里插入图片描述

    可以看到此函数是用来寻找一个字符串中是否含有另一个字符串

    代码示例:

    int main()
    {
    	char str1[] = "abbbbcd";
    	char str2[] = "bbc";
    	char* ret = strstr(str1, str2);
    	printf("%s\n", ret);
    
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    结果:
    在这里插入图片描述

    模拟实现:

    思路:

    整体思路:
    1.当相对应的位相等时,让指向两个字符串的指针++,进行遍历
    2.如若不等时,让子串指针回到起点,主串指针回到开始遍历的下一位,进行新一轮的比较
    详细思路:
    1.首先我们会接受两个字符串的指针参数,但我们尽量的不用原始的指针进行操作,这既是保护了他们的安全,也会更方便的找到起始位置
    2.故我们先创建 s1与 s2分别作为子串与主串用来遍历的指针,再创建一个 ret的指针用来返回参数
    3.开始比较之前有一个先决条件,即 ret所指向的字符串不为空,因为 ret是用来返回找到字符串后的开始遍历地址,若是空字符串就没必要判断。
    4.现在开始比较,利用 while循环,相同则两 指针++,直到两方不相等,此时跳出循环,我们需要判断跳出的 s2指针是否是 0,
    如果是,就代表找到了,
    如果不是,需要 ret++,因为当前的ret已经不可能是子串在主串的起始位置。
    5.进行新一轮的判断,注意新一轮开始后 重置s1与s2指针

    代码实现:

    char* my_strstr(const char* str1, const char* str2)
    {
    	char* s1 = str1;
    	char* ret = str1;
    	char* s2 = str2;
    	assert(str1 && str2);
    	while (*ret)
    	{
    		s1 = ret;
    		s2 = str2;
    		while (s1 && s2 && *s1 == *s2)//防止解引用到空指针
    		{
    			s1++;
    			s2++;
    		}
    		if (*s2 == 0)
    			return ret;
    		ret++;
    	}
    }
    
    int main()
    {
    	char str1[] = "abbbcdef";
    	char str2[] = "bbc";
    	printf("%s\n", my_strstr(str1, str2));
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    欢迎纠错与讨论

  • 相关阅读:
    pandas教程:Essential Functionality 索引 过滤 映射 排序
    题记(43)--C翻转(矩阵旋转)
    MySQL超详细安装教程 手把手教你安装MySQL到使用MySQL 最简单的MySQL安装方式,这种方式装,卸载也简单
    第十三章 Python操作数据库
    反射
    sqoop部署
    【入门深入篇】本章包括条件查询、排序查询、分页查询、分页实战举例(小程序之云函数开发入门到使用发布上线实操)
    巧用CSS3之进击的青豆
    阅读笔记——《GANFuzz: A GAN-based industrial network protocol fuzzing framework》
    在Postman中调用JShaman免费JS混淆加密接口,实现JS代码加密
  • 原文地址:https://blog.csdn.net/2301_78636079/article/details/133501429
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号