strspn(返回字符串中第一个不在指定字符串中出现的字符下标)
表头文件string.h
定义函数:
size_t strspn (const char s,const char accept);
函数说明 strspn()从参数s 字符串的开头计算连续的字符,而这些字符都完全是accept 所指字符串中的字符。简单的说,
!!!若strspn()返回的数值为n,则代表字符串s 开头连续有n 个字符都是属于字符串accept内的字符。!!!
返回值 返回字符串s开头连续包含字符串accept内的字符数目。
#include <iostream>
using namespace std;
int main()
{
char str[]="Linux was first developed for 386/486-based pcs.";
//printf("%d\n",strspn(str,"Linux"));
const char *temp = "Linux was first";
printf("%d is span \n",strspn(str,temp));
system("pause");
return 0;
}
strbrk
功能:
依次检验字符串s1中的字符,当被检验字符在字符串s2中也包含时,则停止检验,并返回该字符位置,空字符null不包括在内。
说明:
在源字符串(s1)中找出最先含有搜索字符串(s2)中任一字符的位置并返回,若找不到则返回空指针。
例子
extern char *strpbrk(const char *s1, const char *s2);
char * strpbrk(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;
}
举例:
// strpbrk.c
#include <stdio.h>
#include<stdlib.h>
#include <string.h>
main()
{
char *s1="Welcome To Beijing";
char *s2="loc";
char *p;
system("cls");
/*Example 1*/
p=strpbrk(s1,s2);
if(p)
{
printf("%s\n",p); /*Output "lcome To Beijing"*/
}
else
{
printf("Not Found!\n");
}
/*Example 2*/
p=strpbrk(s1, "Da");
if(p)
{
printf("%s",p);
}
else
{
printf("Not Found!"); /*"Da" is not found*/
}
getchar();
return 0;
}