strstr c语言字符串,C字符串处理strstr, strindex

有的时候,我们为了一些特殊的需要,不能使用C语言提供的字符串处理函数,而需要我们自己动手来写,下面是两个比较常用的例子:

(1) strstr

原型声明:char *strstr (const char *s1, char *s2);

改函数从字符串s2中查找子字符串s1, 如果找到了返回子找到位置的子字符串的指针,否则返回NULL.

(2)strindex

原型声明:int strindex (const char *s1, char *s2);

返回字符串s2在字符串s1中的位置,这个位置是从0开始的,如果没有找到,则返回-1

下面是实现以及使用的例子:

/*

File Name: str.c

Function: to find a sub string in a string.

*/

#includechar *strstr (const char *s1, const char *s2);

int strindex (const char *s1, const char *s2);

int main()

{

char *s1 = "Hello, Welcome to linux world.";

char *s2 = "linux";

char *res = NULL;

printf("string: %s\n", s1);

printf("sub string: %s\n", s2);

printf("now we will find sub string \"%s\" in \"%s\"\n", s2, s1);

if ( (res = strstr(s1, s2)) == NULL )

{

printf("Can't find the string %s in %s\n", s2, s1);

}

else

{

printf("Find string: %s\n", res);

printf("The position [zero-based] is %d\n", strindex(s1, s2));

}

return 0;

}

char *strstr (const char *s1, const char *s2)

{

unsigned int i = 0;

if ( *s1 == 0 ) // 如果字符串s1为空

{

if ( *s2 ) // 如果字符串s2不为空

return (char*)NULL; // 则返回NULL

return (char*)s1; // 如果s2也为空,则返回s1

}

while ( *s1 ) // 串s1没有结束

{

i = 0;

while ( 1 )

{

if ( s2[i] == 0 )

{

return (char*)s1;

}

if ( s2[i] != s1[i] )

break;

i++;

}

s1++;

}

return (char*)NULL;

}

int strindex(const char *s1, const char *s2)

{

int nPos = -1;

char *res = strstr(s1, s2);

if ( res )

nPos = res - s1 ;

return nPos;

}

阅读(3429) | 评论(0) | 转发(1) |

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值