strspn函数和strbrk函数

strspn(返回字符串中第一个不在指定字符串中出现的字符下标)
表头文件string.h
定义函数:
size_t strspn (const char s,const char accept);
函数说明 strspn()从参数s 字符串的开头计算连续的字符,而这些字符都完全是accept 所指字符串中的字符。简单的说,

!!!若strspn()返回的数值为n,则代表字符串s 开头连续有n 个字符都是属于字符串accept内的字符。!!!

返回值 返回字符串s开头连续包含字符串accept内的字符数目。

#include 
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 
#include
#include 
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;
}

你可能感兴趣的:(函数,strspn,strbrk)