字符串知识1 (strcmp,strncmp,strstr)

L1-070 吃火锅

参考了一下网上的代码,学到了三种字符串函数:

1.strncmp(const char* str1, const char* str2, int num) 

        若在规定长度 n 内两个字符串相同,返回 0 ;否则比较第一个不同位置上的字符的ASCII码,返回 - 1 , 或 1 。

2.strcmp(const char* str1, const char* str2)

        如果返回值小于 0,则表示 str1 小于 str2。如果返回值大于 0,则表示 str1 大于 str2。如果返回值等于 0,则表示 str1 等于 str2。

        样例:

 char arr1[] = {"abcde"};

char arr2[] = {"abcde"};

int ret = strcmp(arr1, arr2);

printf("%d", ret);

3.strstr(const char *haystack, const char *needle)

        其中,haystack是要被检索的C字符串,needle是在haystack字符串内要搜索的小字符串1。如果在haystack中找到了needle,该函数返回指向haystack中第一次出现needle的位置的指针;如果未找到,则返回NULL。

        样例1:输出子串

const char haystack[20] = "RUNOOB";

const char needle[10] = "NOOB";

// 调用strstr函数查找needle在haystack中的位置

char *ret;

ret = strstr(haystack, needle);

printf("子字符串是: %s\n", ret);

输出:

子字符串 ret 是: NOOB

        样例2:替换子串

char str[] = "This is a simple string";

char *pch;

// 调用strstr函数查找"simple"在str中的位置

pch = strstr(str, "simple");

 

// 如果找到了,就用"sample"替换"simple"

if (pch != NULL)

strncpy(pch, "sample", 6);

puts(str);

输出:

This is a sample string

        样例3:使用strstr函数和一个循环计数器统计一个字符串在另一个字符串中出现的次数

char a1[1001], a2[1001];

scanf("%s %s", a1, a2);

// 定义一个指针和一个计数器

char *p;

int k = 0;

// 调用strstr函数循环查找a2在a1中出现的次数

p = a1;

while ((p = strstr(p, a2)) != NULL)

{

k++;

p++;

}

printf("%d", k);

输出:

5

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/543533.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

tomcat 实现会话绑定

Tomcat 后端服务器实现 Session ID会话保持 基础架构: 7-6 代理服务器nginx配置 7-3 tomcat 服务器 7-5 同理 测试: 此时刷新,会话ID一直在变,这样不好 如何解决呢? 不好的是确定ip之后,会一直在一台机上…

docker实战(3)

1, jdk17版本的dockerfile FROM eclipse-temurin:17-jre ADD ./target/ods-poc-0.0.1-SNAPSHOT.jar /home/app/app.jar WORKDIR /home/app ENV TZ Asia/Shanghai ENTRYPOINT ["java","-jar","/home/app/app.jar"] EXPOSE 8083dockerfile 1, …

“技多不压身”是什么意思?看完这篇文章你会明白:有了手艺,走遍天下都不怕!

“技多不压身”是什么意思?看完这篇文章你会明白:有了手艺,走遍天下都不怕! 咱们的老祖宗流传一句话:“一招鲜,吃遍天。”这话说得直白,却道出了学一门手艺或技术对于人生的重要性。“李秘书讲…

HarmonyOS NEXT应用开发—状态栏显隐变化

介绍 本示例介绍使用Scroll组件的滚动事件 onScroll 实现状态栏显隐变化。该场景多用于各种软件的首页、我的等页面中。 效果预览图 使用说明 加载完成后显示状态栏显隐变化页面,上下拖动屏幕,顶端状态栏出现显隐变化。 实现思路 在置顶位置使用sta…

查询ES之细化需求实现多字段、范围过滤、加权和高亮

多字段查询和过滤 一次从两个字段中查询同一个搜索词,比如从title和content中进行查询,另外指定active字段的值必须为true(一般代表该文档未被删除或隐藏): GET /docwrite2/_search { "query": { "…

如何本地搭建hMailServer邮件服务

文章目录 前言1. 安装hMailServer2. 设置hMailServer3. 客户端安装添加账号4. 测试发送邮件5. 安装cpolar6. 创建公网地址7. 测试远程发送邮件8. 固定连接公网地址9. 测试固定远程地址发送邮件 前言 hMailServer 是一个邮件服务器,通过它我们可以搭建自己的邮件服务,通过cpola…

算法学习 | day19/60 二叉搜索树的最近公共祖先/二叉搜索树中的插入操作/删除二叉搜索树中的节点

一、题目打卡 1.1 二叉搜索树的最近公共祖先(借助答案的思路) 题目链接:. - 力扣(LeetCode) class Solution { public:TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {if(!root) return…

Midjourney视觉垫图

https://github.com/lllyasviel/Fooocus/discussions/117https://github.com/lllyasviel/Fooocus/discussions/117掌握Midjourney的垫图技巧:AI绘画中的参考利器本期将深入了解AI绘画的垫图技巧,让作品获得更好的出图效果https://mp.weixin.qq.com/s/RS2…

【算法训练营】周测1

清华大学驭风计划课程链接 学堂在线 - 精品在线课程学习平台 (xuetangx.com) 如果需要答案代码可以私聊博主 有任何疑问或者问题,也欢迎私信博主,大家可以相互讨论交流哟~~ 考题11-1 题目描述 有一个初始时为空的序列,你的任务是维护这个…

代码随想录算法训练营第40天 | 343. 整数拆分 ,96.不同的二叉搜索树

动态规划章节理论基础: https://programmercarl.com/%E5%8A%A8%E6%80%81%E8%A7%84%E5%88%92%E7%90%86%E8%AE%BA%E5%9F%BA%E7%A1%80.html 343. 整数拆分 题目链接:https://leetcode.cn/problems/integer-break/ 思路: 动规五部曲&#xf…

C语言 之 结构体超详细总结

🌈 个人主页:白子寰 🔥 分类专栏:魔法指针,进阶C,C语言,C语言题集,C语言实现游戏👈 希望得到您的订阅和支持~ 💡 坚持创作博文(平均质量分78.8),分…

文件包含例子

一、常见的文件包含函数 php中常见的文件包含函数有以下四种: include() require() include_once() require()_once() include与require基本是相同的,除了错误处理方面: include(),只生成警告(E_WARNING)&#x…