模拟实现在一个字符串中查找一个字符串
2015-10-27 22:01
225 查看
在标准库中有一个函数strstr()用于在一个字符串中查找一个规定的字符串,这个函数可以模拟实现一下,代码如下:
本文出自 “敲完代码好睡觉zzz” 博客,请务必保留此出处http://2627lounuo.blog.51cto.com/10696599/1706978
#include <stdio.h> #include <assert.h> char *my_strstr(const char str[],const char strstr[]) { int i = 0,j = 0,k = 0; assert(str != NULL); assert(strstr != NULL); for(i = 0;str[i] != '\0';i++) { k = i; for(j = 0,k = i;(strstr[j] != '\0')&&(str[k] == strstr[j]);j++,k++) { ; } if(strstr[j] == '\0') return strstr; } if(str[i] == '\0') return NULL; } int main() { int c = 0; char *p; char *str = "abcdddddefgh"; char *strstr = "ddddef"; p = my_strstr(str,strstr); if(p == NULL) printf("not exist\n"); else printf("%s\n",p); return 0; }因为字符串str与字符串strstr不需要被更改,所以可用const来限定,而在函数开始处设定assert来用于断定字符串是否为NULL,assert为条件断言,只在debug下生效,在release下不会被编译,判断条件为真继续执行代码,为假则报错。
本文出自 “敲完代码好睡觉zzz” 博客,请务必保留此出处http://2627lounuo.blog.51cto.com/10696599/1706978
相关文章推荐
- Java实现排序算法之冒泡排序
- MySQL的varchar定义长度到底是字节还是字符
- 【日常学习】【高精】【数学递推】tyvj1375 山洞历险题解
- 分布式系统概念--第一篇 一致性协议、一致性模型、拜占庭问题、租约、副本协议
- 重要的JAVA-API StringBuffer类
- fixed在ie6下抖
- java基础 集合框架 简单总结
- 2012天津E题
- 使用Quartz创建定时任务
- EC读书笔记系列之2:条款4 确定对象被使用前已先被初始化
- 8.滑动事件处理
- jps无法获取到tomcat(java)进程
- gettimeofday windows上的实现
- BZOJ 1064 假面舞会(NOI2008) DFS判环
- 倒序输出字符串
- HDU2795-Billboard 【线段树】
- PHP基于数组的分页函数(核心函数array_slice())
- BZOJ 1064 假面舞会(NOI2008) DFS判环
- 让asp.net web api同时支持[AcceptVerbs("GET","POST")]
- PHP局部变量与全局变量