这些函数,让你的代码更简洁有力!
比较字符串的字典序是一件麻烦的事,相信敲惯了代码的你一定深有同感……但是,今天我们要介绍一个函数,让他帮你“秒杀”字典序问题!
那么,今天我们的主角是谁呢?
那就是
我们最最亲爱的
strcmp函数!
大家有没有尝试过这样一段代码——
char c;
scanf("%s",&c);
printf("%d",c);
然后会出现这样的结果——

不必惊呼,年轻人总觉得这很神奇。
大家知道,其实字符的输入输出,跟美国人们发明的电报有关系,美国人发明了一种ASCII编码表,里面包含着常用的字符,后来这一套就被计算机学着走了。
这张表长什么样子呢?如下所示:

我们可以看到,字母a对应的十进制值就是97。(此表来自百度百科)
那么strcmp究竟是什么,能干什么呢?
如果把strcmp用自定义函数写出来,它大概是这样的:
int strcmp(char str1[101],char str2[101]){
int i=0;
for(int i=0;i<=max(strlen(str1),strlen(str2));i++){
if(str1[i]<str2[i])return -1;
if(str1[i]>str2[i])return 1;
i++;
}
return 0;
}
如果str[1]比str[2]大,则返回一个正数,如果比str[2]小,则返回一个负数,如果相等,则返回0。
它的头文件是< cstring >不过现在用一个< bits/stdc++ >就搞定了。
好了,今天的讲解就结束了,如果你喜欢这篇文章,别忘了点个赞,关注Devrt-飞电鼠哟!
附:
strcmp=string(字符串) compare(比较)
【信息学竞赛真题! ! !】信息学竞赛人必看的「NOIP2011」铺地毯 题解(C++版)
【信息学竞赛真题! ! !】信息学竞赛人必看的「NOIP2011」铺地毯 题解(C++版)
关注Devrt-飞电鼠,了解更多信息学知识与真题!
本文介绍了C++中的strcmp函数,用于比较字符串的字典序。通过示例解释了strcmp的工作原理,它根据ASCII编码比较字符串,并返回比较结果。文章还提到了ASCII编码表和其在字符输入输出中的作用。最后,作者鼓励读者关注Devrt-飞电鼠获取更多信息学竞赛知识。

被折叠的 条评论
为什么被折叠?



