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

商标注册网上申请流程25个步骤爱站工具seo综合查询

商标注册网上申请流程25个步骤,爱站工具seo综合查询,阿里云官方网站,百度智能云windows系统服务器建站一、函数介绍 strstr 是 C 语言标准库 <string.h> 中的字符串查找函数&#xff0c;用于在主字符串中查找子字符串的首次出现位置。若找到子串&#xff0c;返回其首次出现的地址&#xff1b;否则返回 NULL。它是处理字符串匹配问题的核心工具之一。 二、函数原型 char …

一、函数介绍

strstr 是 C 语言标准库 <string.h> 中的字符串查找函数,用于在主字符串中查找子字符串的首次出现位置。若找到子串,返回其首次出现的地址;否则返回 NULL。它是处理字符串匹配问题的核心工具之一。

二、函数原型

char *strstr(const char *haystack, const char *needle);
  • 参数说明

    • haystack:主字符串(被查找的字符串)。

    • needle:子字符串(要查找的目标)。

  • 返回值

    • 找到时:返回子串首次出现的指针地址

    • 未找到时:返回 NULL

  • 特点:区分大小写,如 "Hello" 中查找 "hello" 会失败。

三、基础用法示例

1. 查找成功场景

#include <stdio.h>
#include <string.h>int main() 
{char str[] = "Welcome to MY CSDN blog!";char sub[] = "CSDN";char *result = strstr(str, sub);if (result != NULL){printf("找到子串!位置:%ld\n", result - str);  // 输出:找到子串!位置:14printf("匹配内容:%s\n", result);              // 输出:CSDN blog!
} 
else 
{printf("未找到子串。\n");
}return 0;
}

 2. 查找失败场景

char *result = strstr("Apple", "app");  // 返回NULL(大小写敏感)

 四.模拟实现
const char* my_strstr(const char* str1, const char* str2)
{const char* s1 = NULL;const char* s2 = NULL;const char* cur = str1;assert(str1 && str2);if (*str2 == '\0')//特殊场景return str1;while (*cur){s1 = cur;s2 = str2;while (*s1 && *s2  && *s1 == *s2){s1++;s2++;}if (*s2 == '\0')return cur;cur++;}return NULL;
}int main()
{char arr1[] = "abbbcdef";char arr2[] = "bbc";const char* ret = my_strstr(arr1, arr2);if (ret == NULL)printf("找不到\n");elseprintf("%s\n", ret);return 0;
}
分析:

这里需要创造三个指针,cur用来储存运算的地址。

1.   进行外层while循环(*cur)判断条件逐个往后排序知道遇到\0,在外层循环中,s1 被初始化为当前的 cur 位置,即 str1 中的当前位置;s2 被初始化为 str2 的起始位置。再进行内层while循环,while的判断条件是
     1  *s1 和 *s2 都不为 \0(即两个字符串都没有到达末尾)
     2.  *s1 == *s2(即当前字符相同)。

     3. 如果上述条件都满足,则 s1 和 s2 都向后移动一个字符位置(s1++ 和 s2++),继续比较下一个字符。(这一行代码确保了在两个字符串都不为空且当前字符相等的情况下,继续比较下一个字符,从而实现字符串的逐字符匹配。)

匹配结果:

内层的 while 循环结束时,检查 *s2 是否为 \0。如果是,则说明 str2 已经完全匹配了 str1 中的一个子串,此时返回 cur,即匹配开始的位置。

如果不是,则继续外层循环,从 str1 的下一个字符开始重新尝试匹配。(cur++)

如果外层循环结束且没有找到匹配的子串,则返回 NULL

总结:

外层循环遍历 str1 的每一个可能的起始位置,内层循环则负责从该位置开始逐字符比较 str1 和 str2,直到找到匹配的子串或确定没有匹配为止。

http://www.dtcms.com/wzjs/373735.html

相关文章:

  • 做鸡蛋仔冰淇淋店网站推广普通话的意义论文
  • 大良营销网站建设咨询找个网站
  • 万江区网站仿做网络营销策略包括哪四种
  • 简洁商城网站模板百度站长工具验证
  • 一级a做爰片软件网站外链代发2分一条
  • 页游排行榜前十名网络游戏优化官网咨询
  • 室内设计公司 网站建设chatgpt网址
  • 网站域名的所有权爱站工具包的模块有哪些
  • 美食网页制作教程英文网站seo发展前景
  • sem推广方案seo网址大全
  • 蚌埠seo推广郑州百度seo关键词
  • 张店网站建设公司注册域名要钱吗
  • 做网站是比特币的数字营销包括哪六种方式
  • 做淘宝客网站用什么源码好网站长尾关键词排名软件
  • 做网站需要几个人北京网站营销seo方案
  • 龙岩企业网站建设制作网络营销郑州优化推广公司
  • 资源网站优化排名网站外贸找客户有什么网站
  • 国内装饰行业网站制作qq推广平台
  • 国内十大电商平台排名seo优化排名方法
  • 西安知名网站建设公司搜索排名影响因素
  • 企业网站建设 南通武汉seo价格
  • 青岛模板化网站建设营销工具
  • 如何免费建站seo资讯网
  • 免费x网站域名全网搜索引擎优化
  • 顺企网贵阳网站建设软件培训班
  • 怎么添加网站外贸是做什么的
  • 网站内怎么做链接黑帽seo优化
  • 珠海网站快速排名提升b2b网站
  • 长沙网站设百度地图导航手机版免费下载
  • 公司网站可以自己做吗百度用户服务中心官网电话