c 跟字符串有关的函数

时间:2025-05-10 08:34:02

1、字符串查找

strstr       

char * strstr(const char *s1, const char *s2);  
在s1中查找s2,如果找到返回首个s2的首地址 char * strcasestr(const char *s1, const char *s2);
在s1中查找s2,不区分大小写,如果找到返回首个s2的首地址
char * strnstr(const char *s1, const char *s2, size_t n); 
在s1中的前n个字符中去查找s2,如果找到返回首个s2的首地址

2、字符串比较

int strcmp(const char *s1, const char *s2);
比较s1,s2 返回-1:s1<s2 0:s1=s2 1:s1>s2 int strncmp(const char *s1, const char *s2, size_t n);
比较s1,s2前n个字符 返回-1:s1<s2 0:s1=s2 1:s1>s2
  #include<stdio.h>

 int myStrCmp(const char *s1,const char *s2)
{
int i = ;
while(s1[i] != '\0' && s2[i] != '\0')
{
if(s1[i] != s2[i])
return s1[i] - s2[i];
i++;
}
return s1[i] - s2[i];
} int main(void)
{
char arr[],brr[],ch;
scanf("%[^\n]", arr);
getchar();
scanf("%[^\n]", brr);
printf("%d\n", myStrCmp(arr,brr));
return ;
}

3、字符串拼接

char * strcat(char *restrict s1, const char *restrict s2);
将s2拼接到s1上。
char * strncat(char *restrict s1, const char *restrict s2, size_t n);
将s2的前n个字符拼接到s1上
 char * myStrcat(char *s1,const char *s2)
{
int i = ,j = ;
while(s1[i] != '\0')
{
i++;
}
while()
{
s1[i+j] = s2[j];
if(s2[j] == '\0')
break;
j++;
}
return s1;
}

4、分割字符串

char * strtok(char * str, const char * sep);
将可变字符串str,以sep字符串里面的每一个字符作为分隔符进行分割
、改变原来字符串,把分隔符置换成'\0'
char * 分割成功返回分割首地址,分割失败返回NULL
<可用于查找字符串中最长的单词是哪个>
#include<stdio.h>
#include<string.h>
int main(void)
{
char str[] = "Hi, welcone to here";
char *sep = ", "; //字符串
char *p = strtok(str,sep);
while(p)
{
printf("p=%s\n", p);
p = strtok(NULL, sep);//NULL继续往后进行分割
}
return ;
} 运行结果:
Hi
welcome
to
here

查找出字符串中最长的单词

 #include<stdio.h>
#include<string.h>
int main(void)
{
char str[];
scanf("%[^\n]", str);//遇到回车符结束
char *sep = ", ";
char *p = strtok(str,sep),*maxp = NULL;
int count=,maxCount=;
while(p)
{
count = strlen(p);
if(count > maxCount)
{
maxp = p;
maxCount = count;
}
p = strtok(NULL, sep);//NULL继续往后进行分割
}
puts(maxp);
return ;
}

5、strcpy

char * stpcpy(char *dst, const char *src);
把src拷贝到dst中
char * stpncpy(char *restrict dst, const char *restrict src, size_t n);
把src前n个字符拷贝到dst中去
 char * myStrcpy(char *s1, const char *s2)
{
int i = ;
while()
{
s1[i] = s2[i];
if(s2[i] == '\0')
break;
i++;
}
return s1;
}

6、其它函数

isalpha() 判断是否为字母 'a'~'z' 'A'~'Z'
isalnum() 判断是否为数字或字母 '0'~'9' 'a'~'z' 'A'~'Z'
isdigit() 判断是否为数字 '0'~'9'
      0的ASCII是60,判断一个字符是否为数字 c >= '0' && c <= '9' return c - 60
isspace() 判断是否空格' '
isupper() 判断是否为大写 'A'
islower() 判断是否为小写 'a'