题目描述
字符、整数和浮点数都可以按照数值来比较大小,字符串应该怎么比较呢?让我们来编写一个程序,可以比较两个字符串的大小。
-----------------------------------------------------------------------------
编写函数str_cmp():
原型:int str_cmp(char s1[], char s2[]);
功能:按照指定的比较规则,比较字符串s1和s2的大小。若s1==s2,返回0;若s1<s2,返回值是负数;若s1>s2,返回值是正数。若返回值不为0,返回的数值始终是s1和s2中第一个不相同位置的字符ASCII码值之差。
函数的调用格式见“Append Code”。
-----------------------------------------------------------------------------
Invalid Word(禁用单词)错误:在解决这个题目时,某些关键词是不允许被使用的。如果提交的程序中包含了下列的关键词之一,就会产生这个错误。
被禁用的头文件:string.h和ctype.h。
输入
输入为多组字符串,每组有两个字符串s1和s2,分两行输入,长度不超过100个字符。
输出
输出为多行,与每组输入对应输出为一个整数n。n为s1和s2的比较结果,若s1和s2每个位置上的字符都完全一样,输出0,否则输出s1和s2的第一个不相同的字符ASCII码值之差。
样例输入
样例输出
提示
“Append Code”中用到的头文件、全局变量或宏的定义应自行补充。
Append Code
#define MAX_STR_LEN 100000
int str_cmp(char s1[], char s2[])
{
int n = 0, i = 0, j = 0, d, k ,c;
while(s1[i] != '\0')
{
i++;
while(s2[j] != '\0')
{
j++;
}
if(i < j)
d = j;
else
d = i;
for(k = 0; k < d; k++)
{
if(s1[k] != s2[k])
{
c = s1[k] - s2[k];
n++;
break;
}
}
if(n == 0)
{
c = 0;
}
return c;
{
char str1[MAX_STR_LEN], str2[MAX_STR_LEN];
while( (gets(str1) != NULL) && (gets(str2) != NULL) )
printf("%d\n", str_cmp(str1, str2));
return 0;
}