头文件:
#include <include.h>
strpbrk()函数检索两个字符串中首个相同字符的位置,其原型为:
char *strpbrk( char *s1, char *s2);
【参数说明】s1、s2要检索的两个字符串。
strpbrk()从s1的第一个字符向后检索,直到\'\\0\',如果当前字符存在于s2中,那么返回当前字符的地址,并停止检索。
【返回值】如果s1、s2含有相同的字符,那么返回指向s1中第一个相同字符的指针,否则返回NULL。
注意:strpbrk()不会对结束符\'\\0\'进行检索。
【函数示例】输出第一个相同字符之后的内容。
#include<stdio.h>
#include<string.h>
int main(void){
char* s1 = \"http://see.xidian.edu.cn/cpp/u/xitong/\";
char* s2 = \"see\";
char* p = strpbrk(s1,s2);
if(p){
printf(\"The result is: %s\\n\",p);
}else{
printf(\"Sorry!\\n\");
}
return 0;
}
输出结果:
The result is: see.xidian.edu.cn/cpp/u/xitong/
DEMO:实现自己的strpbrk函数
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
#pragma warning (disable:4996)
char *mystrpbrk(const char *cs,const char *ct);
int main(void)
{
char *s1=\"Welcome to Beijing.\";
char *s2=\"BIT\";
char *s3;
s3=mystrpbrk(s1,s2);
printf(\"%s\\n\",s3);
getch();
return 0;
}
/*FROM 百科*/
char *mystrpbrk(const char *cs,const char *ct)
{
const char *sc1,*sc2;
for (sc1=cs;*sc1!=\'\\0\';sc1++)
{
for (sc2=ct;*sc2!=\'\\0\';sc2++)
{
if (*sc1==*sc2)
{
return (char *)sc1;
}
}
}
return NULL;
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
#pragma warning (disable:4996)
int main(void)
{
char *s1=\"Welcome to Beijing.\";
char *s2=\"BIT\";
char *p;
system(\"cls\");
p=strpbrk(s1,s2);
if (p)
{
printf(\"%s\\n\",p);
}
else
{
printf(\"NOT Found\\n\");
}
p=strpbrk(s1,\"i\");
if (p)
{
printf(\"%s\\n\",p);
}
else
{
printf(\"NOT Found\\n\");
}
getch();
return 0;
}
本文地址:https://www.stayed.cn/item/903
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我