字符串函数---其他类型的函数strstr,strtok,strerror函数和字符分类函数字符转换函数努力积累才能进大厂拿offer
每日励志:
不想认命,就去拼命,我始终相信,付出就会有收获,或大或小,或迟或早,始终不会辜负你的努力。有一种落差是,你总是羡慕别人的成功,自己却不敢开始。
前言:
上篇我们学到了,不受长度受限制的字符串函数----strncpy,strncat,strncmp,今天小编讲一些其它类型的函数---strstr,strtok,strerror函数和字符分类函数字符转换函数。
目录
目录
一.strstr函数子字符串查找函数:
1.功能:
2.函数自身的实现方法:
这里可以大致分为两种情况讨论
a)源字符串能够在目标字符串中一次匹配就能找到
大致思路是假设指针s1指向目标字符串首地址,指针s2指向源字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则目标字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,则指针s1和s2,分别后移,直到目标指针s2指向字符'\0',结束例如。
注意:(若s2指针指向字符串首地址的内容和s1指向的字符串地址的内容相同,我们称之为第
n次匹配)
#include<stdio.h> #include<string.h> int main() { char arr1[] = "cbbac"; char* ch=strstr(arr1, "bba"); printf("%s", ch); return 0; }
最后函数返回第一次就能匹配成功的首地址。
结果:
b)源字符串多次匹配才能成功
大致思路是假设指针s1指向目标字符串首地址,指针s2指向目标字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则目标字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,假设第一次匹配成功则我们将第一次匹配中的指针s1和s2分别后移,若后移后指针s1和s2指向的内容不相同,则第一次匹配失败,s1回到第一次匹配的首位值得下一位,s2回到首地址,若此时指针s1和s2指向的内容相同则,开启第二次匹配,以此类推直到s2指向空,则匹配成功。
例如:
#include<stdio.h> #include<string.h> int main() { char arr1[] = "aabba"; char* ch=strstr(arr1, "abb"); printf("%s", ch); return 0; }
结果:
3.函数的模拟实现:
思路:
1.源字符串能够在目标字符串中一次匹配就能找到
大致思路是假设指针s1指向原字符串首地址,指针s2指向目标字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则原字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,假设第一次匹配成功则我们将第一次匹配中的指针s1和s2分别后移,若后移后指针s1和s2指向的内容不相同,则第一次匹配失败,s1回到第一次匹配的首位值得下一位,s2回到首地址,若此时指针s1和s2指向的内容相同则,开启第二次匹配,以此类推直到s2指向空,则匹配成功。
2.源字符串多次匹配才能成功
大致思路是假设指针s1指向目标字符串首地址,指针s2指向源字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则目标字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,假设第一次匹配成功则我们将第一次匹配中的指针s1和s2分别后移,若后移后指针s1和s2指向的内容不相同,则第一次匹配失败,s1回到第一次匹配的首位值得下一位,s2回到首地址,若此时指针s1和s2指向的内容相同则,开启第二次匹配,以此类推直到s2指向空,则匹配成功。
3.这里我们以指针p来记录第n此匹配的起始位置;
代码:
#include<stdio.h> #include<assert.h> char* my_strstr(const char* arr1,const char* arr2) { assert(arr1 && arr2); const char* s1 = arr1; const char* s2 = arr2; const char* p = arr1; while (*p) { s1 = p; s2 = arr2; while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2) { s1 ; s2 ; } if (*s2 == '\0') { return (char*)p; } p ; } return NULL; } int main() { char arr1[] = "aabba"; char arr2[] = "abb"; char* ch = my_strstr(arr1, arr2); if (ch == NULL) { printf("子字符串不存在\n"); } printf("%s", ch); return 0; }
结果:
二.strtok切割字符串函数:
1.功能:
在这里解释一下:
2. 代码:
#include<stdio.h> #include<string.h> int main() { const char* sep = "@."; char email[] = "zhangpengwei@bitejiuyeke.com.net"; char cp[40] = { 0 };//"zhangpengwei@bitejiuyeke.com" strcpy(cp, email); char* ret = strtok(cp, sep); if(ret != NULL) printf("%s\n", ret); ret = strtok(NULL, sep); if (ret != NULL) printf("%s\n", ret); ret = strtok(NULL, sep); if (ret != NULL) printf("%s\n", ret); ret = strtok(NULL, sep); if (ret != NULL) printf("%s\n", ret); return 0; }
以为这就完了?
事实上代码可以进行简化:
#include<stdio.h> #include<string.h> int main() { const char* sep = "@."; char email[] = "zhangpengwei@bitejiuyeke.com.net"; char cp[40] = { 0 };//"zhangpengwei@bitejiuyeke.com" strcpy(cp, email); char* ret = NULL; for (ret = strtok(cp, sep); ret != NULL; ret=strtok(NULL, sep)) { printf("%s\n", ret); } return 0; }
3.结果:
4.模拟strtok:
a)代码:
#include<stdio.h> #include<assert.h> #include<string.h> //模拟实现strtok 字符串切割函数 char* my_strtok(char* str1, const char* str2) { assert(str2); static int sz1 = NULL; static int count = NULL; static char* s1 = NULL; static char* s2 = NULL; int sz = 0; if (str1 != NULL)//说明是第一次进入。 { sz1 = strlen(str1);//计算出str1中所有字符的个数 s2 = str1;//记录初始地址,等下找到分割符时,将这个地址返回。 sz = strlen(str2); for (*str1; *str1 != 0; str1 ) { for (int i = 0; i < sz; i ) { if (i == 0) { count ; } if (*str1 == *(str2 i)) { *str1 = 0; s1 = str1;//记录这一次置0的位置。 return s2; } } } } else { s2 = s1 1; str1 = s2; sz = strlen(str2); for (*str1; *str1 != 0; str1 ) { for (int i = 0; i < sz; i ) { if (i == 0) { count ; } if (*str1 == *(str2 i)) { *str1 = 0; s1 = str1;//记录这一次置0的位置。 return s2; } } } if (count > sz1) { return NULL; } return s2; } } int main() { char arr[20] = "12@34.5"; char* p = "@."; char* str = NULL; for (str = my_strtok(arr, p); str != NULL; str = my_strtok(NULL, p)) { printf("%s\n", str); } return 0; }
b)结果:
这里需要注意的就是当目的字符串被遍历完成之后,再次调用该函数会返回一个NULL指针。我是以计数器的方式进行实现,每当成功比对一个字符,就进行一次计数,当计数的个数比目的字符串字符个数大时,说明目的字符串被遍历完成了,此时会返回空指针。
三.strerror错误报告函数:
1.功能:
返回错误码,所对应的错误信息。
2.代码:
a)
注意:
C语言的库函数,在执行失败的时候,都会设置错误码 0 1 2 3 4 5 6 7 8
#include<stdio.h> #include<string.h> int main() { printf("%s\n", strerror(0)); printf("%s\n", strerror(1)); printf("%s\n", strerror(2)); printf("%s\n", strerror(3)); printf("%s\n", strerror(4)); printf("%s\n", strerror(5)); return 0; }
结果:
b)
errno - C语言设置的一个全局的错误码存放的变量
-
#include<stdio.h>
-
#include<string.h>
-
#include<errno.h>
-
int main()
-
{
-
FILE* pf = fopen("C:\\Users\\zpeng\\Desktop\\test.txt", "r");
-
if (pf == NULL)
-
{
-
printf("%s\n", strerror(errno));
-
return 1;
-
}
-
else
-
{
-
//
-
}
-
return 0;
-
}
如果文件夹不在会返回错误信息进行提醒:
四.字符分类函数:
函数
|
如果他的参数符合下列条件就返回真
|
iscntr
|
任何控制字符
|
isspace
|
空白字符:空格 ‘ ’ ,换页 ‘\f’ ,换行 '\n' ,回车 ‘\r’ ,制表符 '\t' 或者垂直制表符 '\v'
|
isdigit
|
十进制数字 0~9
|
isxdigit
|
十六进制数字,包括所有十进制数字,小写字母 a~f ,大写字母 A~F
|
islower
|
小写字母 a~z
|
isupper
|
大写字母 A~Z
|
isalpha
|
字母 a~z 或 A~Z
|
isalnum
|
字母或者数字, a~z,A~Z,0~9
|
ispunct
|
标点符号,任何不属于数字或者字母的图形字符(可打印)
|
isgraph
|
任何图形字符
|
isprint
|
任何可打印字符,包括图形字符和空白字符
|
五.字符转换函数:
int tolower ( int c )int toupper ( int c )
六:自负转换函数与自负分类函数综合案例
1.代码:
int main() { int i = 0; char str[] = "Test String.\n"; char c; while (str[i]) { c = str[i]; if (isupper(c)) c = tolower(c); putchar(c); i ; } return 0; }
2. 结果:
结语:
每个人的成长都是能力和想要得到的东西,不断匹配的过程,当你的才华和欲望不匹配时,你就该静下心来学习了,如果小编的总结能对你有所帮助,希望小伙伴们三连加关注哦,你的支持是小编创作的最大动力。
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhgbjbff
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01