用c语言实现字符串的查找,C语言字符串查找的几种实现

/*********************************************************************

* Author  : Samson

* Date    : 01/09/2012

* Test platform:

*               GNU Linux version 2.6.29.4

*               gcc version 4.4.0 20090506 (Red Hat 4.4.0-4) (GCC)

* *******************************************************************/

/* locate a substring */

char * _strstr(char *s1, char *s2)

{

char c1, c2;

int sublen = _strlen(s2);

c2 = *s2++;

do

{

do

{

c1 = *s1++;

if(0 == c1)

return NULL;

}while(c1 != c2);

}while(_strncmp(s1, s2, sublen));

return --s1;

}

/* locate  substring of N characters */

char * _strstrn(char *s1, char *s2, int n)

{

char c1, c2;

c2 = *s2++;

do

{

do

{

c1 = *s1++;

if(0 == c1)

{

return NULL;

}

}while(c1 != c2);

}while(_strncmp(s1, s2, n - 1));

return --s1;

}

/* locate  substring of N characters and Ignore case*/

unsigned char * _strnocasestrn(unsigned char *s1, unsigned char *s2, int n)

{

unsigned char c1, c2;

c2 = *s2++;

(c2 >= 'A' && c2 <= 'Z') ? (c2 | 0x20) : c2;

do

{

do

{

c1 = *s1++;

if(0 == c1)

return NULL;

c1 = (c1 >= 'A' && c1 <= 'Z') ? (c1 | 0x20) : c1;

}while(c1 != c2);

}while(_strncmp(s1, s2, n - 1) != 0);

return --s1;

}

以上实现中的_strncmp请参照http://blog.csdn.net/yygydjkthh/article/details/7188518中的具体实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值