查找子串
发布日期:2021-06-29 11:17:52
浏览次数:2
分类:技术文章
本文共 1018 字,大约阅读时间需要 3 分钟。
本题要求实现一个字符串查找的简单函数。
函数接口定义:
char *search( char *s, char *t );
函数search在字符串s中查找子串t,返回子串t在s中的首地址。若未找到,则返回NULL。
裁判测试程序样例:
#include#define MAXS 30char *search(char *s, char *t);void ReadString( char s[] ); /* 裁判提供,细节不表 */int main(){ char s[MAXS], t[MAXS], *pos; ReadString(s); ReadString(t); pos = search(s, t); if ( pos != NULL ) printf("%d\n", pos - s); else printf("-1\n"); return 0;}/* 你的代码将被嵌在这里 */
输入样例1:
The C Programming Languageram
输出样例1:
10
输入样例2:
The C Programming Languagebored
输出样例2:
-1
思路:匹配算法,关键是用一个指针记录开始匹配时指向s字符串的当前位置,匹配时该指针不动。若匹配失败,指针移动到s字符串的下一位置(并重置指向t字符串的指针),再重新开始匹配。可以对照strstr函数来看。
char *search(char *s, char *t) { char *p = s;//用作表示指向s字符串的当前位置 char *s1;//检查s char *t1;//检查t while (*p) { s1 = p; t1 = t;//回到t的首位置再开始匹配 while ((*s1) && (*t1) && (*s1 == *t1)) { //开始匹配 s1++,t1++; } if (*t1 == 0) { //表明找到了 return p; } p++;//移到下一位置再继续匹配 } return NULL;}
转载地址:https://blog.csdn.net/zxc0074869/article/details/115129722 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月03日 06时17分30秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
初入行的C++程序员,如何快速摆脱CRUD阶段?
2019-04-29
研究生跟了一个很棒的导师是种怎样的体验?
2019-04-29
学会扶墙的机器人:没有什么能让我倒下!
2019-04-29
美国无人机在火星首飞成功,创造历史,3米飞行高度悬停30秒
2019-04-29
单片机的几种数字滤波算法
2019-04-29
用单片机控制导弹?
2019-04-29
各种滤波器合集!
2019-04-29
国产CPU深度研究报告(干货,110页)
2019-04-29
在电路中,耦合是什么?有哪些方式?
2019-04-29
变局之际,聊聊物联网的过去、现在和未来
2019-04-29
缺货涨价很久的MCU的国产和国外厂家汇总!(80家)
2019-04-29
单片机6年想转嵌入式Linux ,不知如何下手?
2019-04-29
拆解 | 某平台19元的儿童电话手表,究竟怎么做到的?
2019-04-29
五一好礼70份免费送:示波器、开发板、焊台等!
2019-04-29
2纳米芯片问世!芯片性能要起飞?!
2019-04-29
ARM Cortex系列那么多处理器,该怎么区分?
2019-04-29
知乎:学计算机的女生都怎么样了?
2019-04-29
华为重磅反击,鸿蒙来了!
2019-04-29
常用电子接口大全,遇到不认识的,就翻出来对照辨认!
2019-04-29
芯片IC附近为啥要放0.1uF的电容?
2019-04-29