英文看着麻烦,咱给他先翻译一下。
字符串比较函数
分数 30
作者 翁恺
单位 浙江大学
按照标准库中的方式实现strcmp()。
函数接口定义:
int mycmp(const int *s1,const int *s2);
当s1等于s2时返回0,
否则返回s1和s2之间的距离。
首先呢,要写出自己的mycmp函数,理解strcmp是不可少的。
strcmp是<string.h>中的函数。strcmp(a,b),意为比较字符串a与字符串b。
当两个串相等时,返回值为0;
当a与b不相等时,根据ASCII码比较串a和串b中从左往右第一个不相等的字符a[ i ]与b[ i ]:
①若a[ i ]>b[ i ],则输出a[ i ] - b[ i ],结果是个正数;
②若a[ i ]<b[ i ],同样输出a[ i ] - b[ i ],结果是个负数。
注意!:有的C返回值会是1,0,-1。(对应上述的正数,0,负数)。
OK,基本概念理解完毕,开始手搓代码。
int mycmp(const char* s1,const char* s2){
int i=0,cnt=0;
do{
if(s1[cnt]!=s2[cnt]){
int s=s1[cnt]-s2[cnt]; //当有不相等出现时,比较当前字符并将结果
i=s; //保留到i中。
break; //然后提前结束循环。
}
cnt++;
}while(s1[cnt]!='\0'||s2[cnt]!='\0'); //正常情况下两个都走到其串的结尾循环才结
return i; //束。
}
完美拿下!