//设计一个strmncmp函数,对比普通的strcmp,原则在于,当字符串中含有数字时,以数字大小为标准,对于其中只有一个字符串为数字的情况,
//仍然使用原来的原则,举例说strmncmp的判定结果,”abc”<”abc#”<”abc1”<”abc2”<”abc10”<”abcd”
//一般的strcmp的判定结果:”abc”<”abc#”<”abc1”<”abc10”<”abc2”<”abcd”
//要求:请给出完整代码,在达到目标的情况下尽量搞笑,简洁。
完全字符串比较,避免计算整数的数值,从而导致溢出的情况。
//仍然使用原来的原则,举例说strmncmp的判定结果,”abc”<”abc#”<”abc1”<”abc2”<”abc10”<”abcd”
//一般的strcmp的判定结果:”abc”<”abc#”<”abc1”<”abc10”<”abc2”<”abcd”
//要求:请给出完整代码,在达到目标的情况下尽量搞笑,简洁。
int strmncmp(char* s1, char* s2){
if(!s1&&!s2) return 0;
if(!s1) return -1;
if(!s2) return 1;
while(*s1&&*s2){
if(isDigital(*s1)&&isDigital(*s2)){
//跳过前缀的0
while(*s1=='0')++s1;
while(*s2=='0')++s2;
int curRet;
bool isSet=false;
while(isDigital(*s1)&&isDigital(*s2)){
if(!isSet){//比较第一个不相同的数字,用来处理数字长度相同的情况
if(*s1<*s2) {
curRet = -1;
isSet = true;
}else if(*s1>*s2){
curRet = 1;
isSet = true;
}
}
++s1;
++s2;
}
if(isDigital(*s1)||isDigital(*s2)){//数字长度不同,谁长谁大
return isDigital(*s1) ? 1:-1;
}else if(isSet){ //两者数字的长度相同,并且不完全一样
return curRet;
}else if(*s1==*s2){//当前字符也相等
++s1;
++s2;
}else {
return *s1<*s2 ? -1:1;
}
}else if(*s1==*s2){
++s1;
++s2;
}else {
return *s1<*s2 ? -1:1;
}
}
if(*s1==0&&*s2==0) return 0;
if(*s1) return 1;
return -1;
}完全字符串比较,避免计算整数的数值,从而导致溢出的情况。

本文介绍了一个自定义的strmncmp函数,该函数用于比较字符串,当字符串包含数字时,会根据数字的大小进行比较。在实现过程中,考虑了特殊情况并尽可能简化代码。
1165

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



