頭文件:
#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;}
|
新聞熱點
疑難解答
圖片精選