strcspn

头文件:#inclued<string.h>

strcspn()用来检索字符串s1开头连续有几个字符都不含字符串s2中的字符,其原型为:
int strcspn(char *s1, char *s2);

【参数说明】s1、s2为要进行查找的两个字符串。

strcspn()从字符串s的开头计算连续的字符,而这些字符都完全不在字符串s2中。简单地说,若strcspn()返回的数值为n,则代表字符串s1开头连续有n 个字符都不含字符串s2中的字符。

【返回值】返回字符串s1开头连续不含字符串s2内的字符数目。

注意:strcspn()会检查字符串结束标志'\0';如果s1中的字符都没有在s2中出现,那么将返回s1的长度;检索的字符是区分大小写的。

【函数示例】返回s1、s2包含的相同字符串的位置。
   
   
  1. #include<stdio.h>
  2. #include<string.h>
  3. int main()
  4. {
  5. char* s1 = "http://see.xidian.edu.cn/cpp/u/biaozhunku/";
  6. char* s2 = "c is good";
  7. int n = strcspn(s1,s2);
  8. printf("The first char both in s1 and s2 is :%c\n",s1[n]);
  9. printf("The position in s1 is: %d\n",n);
  10. return 0;
  11. }
#include<stdio.h>
#include<string.h>
int main()
{
    char* s1 = "http://see.xidian.edu.cn/cpp/u/biaozhunku/";
    char* s2 = "c is good";
    int n = strcspn(s1,s2);
    printf("The first char both in s1 and s2 is :%c\n",s1[n]);   
    printf("The position in s1 is: %d\n",n);
    return 0;
}

再看一个例子,判断两个字符串的字符是否有重复的。
   
   
  1. #include<stdio.h>
  2. #include<string.h>
  3. int main()
  4. {
  5. char* s1 = "http://see.xidian.edu.cn/cpp/xitong/";
  6. char* s2 = "z -+*";
  7. if(strlen(s1) == strcspn(s1,s2)){
  8. printf("s1 is diffrent from s2!\n");
  9. }else{
  10. printf("There is at least one same character in s1 and s2!\n");
  11. }
  12. return 0;
  13. }
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值