这题很简单,就是一个大小写转换的算法,可能有一个函数专门做这个事,大家可以查查,我想应该是有的。
那么我的代码思路就是一个个去比较,不管它是大写字母还是小写字母,都一并把它们都专成小写字母,再去比较。
这样的好处是不用消费很多资源和代码就可以达到效果。
#include <stdio.h>
#include <string.h>
// 忽略大小写比较两个字符
int cmpChar(char a, char b)
{
if(('A' <= a) && (a <= 'Z')) a = a + 'a' - 'A';
if(('A' <= b) && (b <= 'Z')) b = b + 'a' - 'A';
if(a > b) return 1;
else if(a == b) return 0;
else return -1;
}
// 比较两个字符串
int strcmpString(char s1[], char s2[])
{
int l1 = strlen(s1);
int l2 = strlen(s2);
int len = (l1 < l2? l1:l2);
for(int i = 0; i < len; ++i)
{
int f = cmpChar(s1[i], s2[i]);
if(f == 1) return 1;
else if(f == -1) return -1;
}
return 0;
}
int main()
{
char str1[100], str2[100];
gets(str1);
gets(str2);
int flag = strcmpString(str1, str2);
if(flag > 0) printf(">\n");
else if(flag < 0) printf("<\n");
else printf("=\n");
return 0;
}
这题其实还可以先把两个字符串都转成大写或小写的字符串,然后直接一个strcmp()解决。这里就不赘述了。