strstr函数 C++

strstr函数 C++strstr函数分类: C/C++2011-08-1310:00 696人阅读 评论(0) 收藏 举报函数名:strstr功能:在串中查找指定字符串的第一次出现用法:char*strstr(char*str1,char*str2);程序例:#include#includeintmain(void){

大家好,又见面了,我是你们的朋友全栈君。

 

strstr函数

分类: C/C++
 
696人阅读 
评论(0) 
收藏 
举报

函数名: strstr
功 能: 在串中查找指定字符串的第一次出现
用 法: char *strstr(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char *str1 = “Borland International”, *str2 = “nation”, *ptr;

   ptr = strstr(str1, str2);
   printf(“The substring is: %s\n”, ptr);
   return 0;
}

函数名: stpcpy
功 能: 拷贝一个字符串到另一个
用 法: char *stpcpy(char *destin, char *source);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char string[10];
   char *str1 = “abcdefghi”;

   stpcpy(string, str1);
   printf(“%s\n”, string);
   return 0;
}

函数名: strcat
功 能: 字符串拼接函数
用 法: char *strcat(char *destin, char *source);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char destination[25];
   char *blank = ” “, *c = “C++”, *Borland = “Borland”;

   strcpy(destination, Borland);
   strcat(destination, blank);
   strcat(destination, c);

   printf(“%s\n”, destination);
   return 0;
}

函数名: strchr
功 能: 在一个串中查找给定字符的第一个匹配之处\
用 法: char *strchr(char *str, char c);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

    char string[15];
    char *ptr, c = ‘r’;

    strcpy(string, “This is a string”);
    ptr = strchr(string, c);
    if (ptr)
       printf(“The character %c is at position: %d\n”, c, ptr-string);
    else
       printf(“The character was not found\n”);
    return 0;
}

函数名: strcmp
功 能: 串比较
用 法: int strcmp(char *str1, char *str2);
看Asic码,str1>str2,返回值 > 0;两串相等,返回0
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

    char *buf1 = “aaa”, *buf2 = “bbb”, *buf3 = “ccc”;
    int ptr;

    ptr = strcmp(buf2, buf1);
    if (ptr > 0)
       printf(“buffer 2 is greater than buffer 1\n”);
    else
       printf(“buffer 2 is less than buffer 1\n”);

    ptr = strcmp(buf2, buf3);
    if (ptr > 0)
       printf(“buffer 2 is greater than buffer 3\n”);
    else
       printf(“buffer 2 is less than buffer 3\n”);

    return 0;
}

函数名: strncmpi
功 能: 将一个串中的一部分与另一个串比较, 不管大小写
用 法: int strncmpi(char *str1, char *str2, unsigned maxlen);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char *buf1 = “BBB”, *buf2 = “bbb”;
   int ptr;

   ptr = strcmpi(buf2, buf1);

   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 1\n”);

   if (ptr < 0)
      printf(“buffer 2 is less than buffer 1\n”);

   if (ptr == 0)
      printf(“buffer 2 equals buffer 1\n”);

   return 0;
}

函数名: strcpy
功 能: 串拷贝
用 法: char *strcpy(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

    char string[10];
    char *str1 = “abcdefghi”;

    strcpy(string, str1);
    printf(“%s\n”, string);
    return 0;
}

函数名: strcspn
功 能: 在串中查找第一个给定字符集内容的段
用 法: int strcspn(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>

int main(void)
{

    char *string1 = “1234567890”;
    char *string2 = “747DC8”;
    int length;

    length = strcspn(string1, string2);
    printf(“Character where strings intersect is at position %d\n”, length);

    return 0;
}

函数名: strdup
功 能: 将串拷贝到新建的位置处
用 法: char *strdup(char *str);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>

int main(void)
{

    char *dup_str, *string = “abcde”;

    dup_str = strdup(string);
    printf(“%s\n”, dup_str);
    free(dup_str);

    return 0;
}

函数名: stricmp
功 能: 以大小写不敏感方式比较两个串
用 法: int stricmp(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char *buf1 = “BBB”, *buf2 = “bbb”;
   int ptr;

   ptr = stricmp(buf2, buf1);

   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 1\n”);

   if (ptr < 0)
      printf(“buffer 2 is less than buffer 1\n”);

   if (ptr == 0)
      printf(“buffer 2 equals buffer 1\n”);

   return 0;
}

函数名: strerror
功 能: 返回指向错误信息字符串的指针
用 法: char *strerror(int errnum);
程序例:

#include <stdio.h>
#include <errno.h>

int main(void)
{

   char *buffer;
   buffer = strerror(errno);
   printf(“Error: %s\n”, buffer);
   return 0;
}

函数名: strcmpi
功 能: 将一个串与另一个比较, 不管大小写
用 法: int strcmpi(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char *buf1 = “BBB”, *buf2 = “bbb”;
   int ptr;

   ptr = strcmpi(buf2, buf1);

   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 1\n”);

   if (ptr < 0)
      printf(“buffer 2 is less than buffer 1\n”);

   if (ptr == 0)
      printf(“buffer 2 equals buffer 1\n”);

   return 0;
}

函数名: strncmp
功 能: 串比较
用 法: int strncmp(char *str1, char *str2, int maxlen);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)

{

   char *buf1 = “aaabbb”, *buf2 = “bbbccc”, *buf3 = “ccc”;
   int ptr;

   ptr = strncmp(buf2,buf1,3);
   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 1\n”);
   else
      printf(“buffer 2 is less than buffer 1\n”);

   ptr = strncmp(buf2,buf3,3);
   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 3\n”);
   else
      printf(“buffer 2 is less than buffer 3\n”);

   return(0);
}

函数名: strncmpi
功 能: 把串中的一部分与另一串中的一部分比较, 不管大小写
用 法: int strncmpi(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char *buf1 = “BBBccc”, *buf2 = “bbbccc”;
   int ptr;

   ptr = strncmpi(buf2,buf1,3);

   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 1\n”);

   if (ptr < 0)
      printf(“buffer 2 is less than buffer 1\n”);

   if (ptr == 0)
      printf(“buffer 2 equals buffer 1\n”);

   return 0;
}

函数名: strncpy
功 能: 串拷贝
用 法: char *strncpy(char *destin, char *source, int maxlen);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char string[10];
   char *str1 = “abcdefghi”;

   strncpy(string, str1, 3);
   string[3] = ‘\0’;
   printf(“%s\n”, string);
   return 0;
}

函数名: strnicmp
功 能: 不注重大小写地比较两个串
用 法: int strnicmp(char *str1, char *str2, unsigned maxlen);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char *buf1 = “BBBccc”, *buf2 = “bbbccc”;
   int ptr;

   ptr = strnicmp(buf2, buf1, 3);

   if (ptr > 0)
      printf(“buffer 2 is greater than buffer 1\n”);

   if (ptr < 0)
      printf(“buffer 2 is less than buffer 1\n”);

   if (ptr == 0)
      printf(“buffer 2 equals buffer 1\n”);

   return 0;
}

函数名: strnset
功 能: 将一个串中的所有字符都设为指定字符
用 法: char *strnset(char *str, char ch, unsigned n);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char string[50] = “abcdefghijklmnopqrstuvwxyz”;
   char letter = ‘x’;

   printf(“string before strnset: %s\n”, string);
   strnset(string, letter, 13);
   printf(“string after strnset: %s\n”, string);

   return 0;
}

函数名: strpbrk
功 能: 在串中查找给定字符集中的字符
用 法: char *strpbrk(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char *string1 = “abcdefghijklmnopqrstuvwxyz”;
   char *string2 = “onm”;
   char *ptr;

   ptr = strpbrk(string1, string2);

   if (ptr)
      printf(“strpbrk found first character: %c\n”, *ptr);
   else
      printf(“strpbrk didn’t find character in set\n”);

   return 0;
}

函数名: strrchr
功 能: 在串中查找指定字符的最后一个出现
用 法: char *strrchr(char *str, char c);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char string[15];
   char *ptr, c = ‘r’;

   strcpy(string, “This is a string”);
   ptr = strrchr(string, c);
   if (ptr)
      printf(“The character %c is at position: %d\n”, c, ptr-string);
   else
      printf(“The character was not found\n”);
   return 0;
}

函数名: strrev
功 能: 串倒转
用 法: char *strrev(char *str);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char *forward = “string”;

   printf(“Before strrev(): %s\n”, forward);
   strrev(forward);
   printf(“After strrev(): %s\n”, forward);
   return 0;
}

函数名: strset
功 能: 将一个串中的所有字符都设为指定字符
用 法: char *strset(char *str, char c);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char string[10] = “123456789”;
   char symbol = ‘c’;

   printf(“Before strset(): %s\n”, string);
   strset(string, symbol);
   printf(“After strset(): %s\n”, string);
   return 0;
}

函数名: strspn
功 能: 在串中查找指定字符集的子集的第一次出现
用 法: int strspn(char *str1, char *str2);
程序例:

#include <stdio.h>
#include <string.h>
#include <alloc.h>

int main(void)
{

   char *string1 = “1234567890”;
   char *string2 = “123DC8”;
   int length;

   length = strspn(string1, string2);
   printf(“Character where strings differ is at position %d\n”, length);
   return 0;
}

函数名: strtod
功 能: 将字符串转换为double型值
用 法: double strtod(char *str, char **endptr);
程序例:

#include <stdio.h>
#include <stdlib.h>

int main(void)
{

   char input[80], *endptr;
   double value;

   printf(“Enter a floating point number:”);
   gets(input);
   value = strtod(input, &endptr);
   printf(“The string is %s the number is %lf\n”, input, value);
   return 0;
}

函数名: strtok
功 能: 查找由在第二个串中指定的分界符分隔开的单词
用 法: char *strtok(char *str1, char *str2);
程序例:

#include <string.h>
#include <stdio.h>

int main(void)
{

   char input[16] = “abc,d”;
   char *p;

  
   p = strtok(input, “,”);
   if (p)   printf(“%s\n”, p);

  
   p = strtok(NULL, “,”);
   if (p)   printf(“%s\n”, p);
   return 0;
}

函数名: strtol
功 能: 将串转换为长整数
用 法: long strtol(char *str, char **endptr, int base);
程序例:

#include <stdlib.h>
#include <stdio.h>

int main(void)
{

   char *string = “87654321”, *endptr;
   long lnumber;

  
   lnumber = strtol(string, &endptr, 10);
   printf(“string = %s long = %ld\n”, string, lnumber);

   return 0;
}

函数名: strupr
功 能: 将串中的小写字母转换为大写字母
用 法: char *strupr(char *str);
程序例:

#include <stdio.h>
#include <string.h>

int main(void)
{

   char *string = “abcdefghijklmnopqrstuvwxyz”, *ptr;

  
   ptr = strupr(string);
   printf(“%s\n”, ptr);
   return 0;
}

函数名: swab
功 能: 交换字节
用 法: void swab (char *from, char *to, int nbytes);
程序例:

#include <stdlib.h>
#include <stdio.h>
#include <string.h>

char source[15] = “rFna koBlrna d”;
char target[15];

int main(void)
{

   swab(source, target, strlen(source));
   printf(“This is target: %s\n”, target);
   return 0;
原型:extern char *strstr(char *haystack, char *needle);
 所在头文件:#include <string.h>
 功能:从字符串haystack中寻找needle第一次出现的位置(不比较结束符NULL)。
 说明:返回指向第一次出现needle位置的指针,如果没找到则返回NULL。

具体使用例子:

Download: 
strstr_sample.c
  1. #include <stdio.h>
  2. #include <string.h>
  3. int main(int argc,char **argv)
  4. {
  5. char *haystack=aaa||a||bbb||c||ee||;
  6. char *needle=||;
  7. char* buf = strstr( haystack, needle);
  8. while( buf != NULL )
  9. {
  10. buf[0]=’\0‘;
  11. printf( %s\n , haystack);
  12. haystack = buf + strlen(needle);
  13. buf = strstr( haystack, needle);
  14. }
  15.    return 0;
  16. }
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/153017.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 2020年再有这三种心态的员工,不会被领导重用,早知道早受益

    2020年再有这三种心态的员工,不会被领导重用,早知道早受益

  • C语言逗号运算符_c语言逗号运算符优先级最低

    C语言逗号运算符_c语言逗号运算符优先级最低逗号也是运算符?是的,但是其实我更愿意说它是分隔符。在C语言中我们就经常使用逗号,看似逗号是非常平凡的分隔符,但是它关联到一个你必须知道但可能未曾思考的小知识:理论上,每条语句(分号结束),最终都会转换成一个值。例子1:#include<stdio.h>intmain(){ 3,4,5;//这是一条语句 //把上面这条语句的值赋值给变量a inta=(3,4,5); printf(“a=%d\n”,a);}输出结果:a=5因为a的值是整条语句的值,

    2022年10月27日
  • ActiveX 部件不能创建对象: ‘scripting.FileSystemObject’

    ActiveX 部件不能创建对象: ‘scripting.FileSystemObject’解决方法:1.首先,是不是从来都是这种情况,如果只是偶尔的,一会儿是,一会儿不是,问题就不好办。如果是本身就有问题,那就是“scrrun.dll”文件未注册。使用regsvr32scrrun.dll就可以2.VB里用setfso=CreateObject("Scripting.FileSystemObject")asp里边用setfso=Serv…

  • 重复字符串 leetcode_字符串中出现最多的子串 leetcode

    重复字符串 leetcode_字符串中出现最多的子串 leetcode原题链接给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。示例 1:输入: s = “abcabcbb”输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。示例 2:输入: s = “bbbbb”输出: 1解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。示例 3:输入: s = “pwwkew”输出: 3解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。 请注意,你的答案必须是 子串 的长度,”pwk

  • cmd版贪吃蛇_贪吃蛇老版本无敌版

    cmd版贪吃蛇_贪吃蛇老版本无敌版importjava.awt.*;importjava.util.LinkedList;importjava.util.Scanner;/***@authoraachen0*@date2018/3/2713:56*IDE:IntelliJIDEA*/publicclassSnakeGame{staticfinalintWIDTH=…

  • initramfs学习「建议收藏」

    initramfs学习「建议收藏」(一)helloworld一、initramfs是什么在2.6版本的linux内核中,都包含一个压缩过的cpio格式的打包文件。当内核启动时,会从这个打包文件中导出文件到内核的rootfs文件系统,然后内核检查rootfs中是否包含有init文件,如果有则执行它,作为PID为1的第一个进程。这个init进程负责启动系统后续的工作,包括定位、挂载“真正的”根文件系统设备(如果有的话)。

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号