您的位置:首页 > 其它

蓝桥杯模拟赛:字符串比较

2017-04-04 09:50 274 查看
我们需要一个新的字符串比较函数compare(s1, s2).

对这个函数要求是:

1. 它返回一个整数,表示比较的结果。

2. 结果为正值,则前一个串大,为负值,后一个串大,否则,相同。

3. 结果的绝对值表示:在第几个字母处发现了两个串不等。

下面是代码实现。对题面的数据,结果为:

-3

2

5

仔细阅读源程序,填写划线位置缺少的代码。

分析:

当发现t不等于0时可知两个串不等

通过递归的返回次数得到第几个字母

所以就是t>0?t+1:t-1;

#include <iostream>
using namespace std;

int compare(const char* s1, const char* s2)
{
if(s1==NULL && s2==NULL) return 0;
if(s1==NULL) return -1;
if(s2==NULL) return 1;

if(*s1 == 0 && *s2== 0) return 0;
if(*s1 == 0) return -1;
if(*s2 == 0) return 1;

if(*s1<*s2) return -1;
if(*s1>*s2) return 1;

int t = compare(s1+1,s2+1);
if(t==0) return 0;

return t>0?t+1:t-1; //填空位置
}

int main()
{
printf("%d\n", compare("abc","abk"));
printf("%d\n", compare("abc","a"));
printf("%d\n", compare("abcde","abcda"));
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: