OJ地址:https://vjudge.net/problem/OpenJ_Bailian-2721
一般我们用strcmp可比较两个字符串的大小,比较方法为对两个字符串从前往后逐个字符相比较(按ASCII码值大小比较),直到出现不同的字符或遇到'\0'为止。如果全部字符都相同,则认为相同;如果出现不相同的字符,则以第一个不相同的字符的比较结果为准。但在有些时候,我们比较字符串的大小时,希望忽略字母的大小,例如"Hello"和"hello"在忽略字母大小写时是相等的。请写一个程序,实现对两个字符串进行忽略字母大小写的大小比较。
Input
输入为两行,每行一个字符串,共两个字符串。(请用gets录入每行字符串)(每个字符串长度都小于80)
Output
如果第一个字符串比第二个字符串小,输出一个字符"<"
如果第一个字符串比第二个字符串大,输出一个字符">"
如果两个字符串相等,输出一个字符"="
Sample Input
Hello
hello
Sample Output
=
思路:
先将字符串的每一个字母转换为全大写(toupper)或者全小写(tolower),在使用strcmp()函数进行比较。
参考:
程序代码:
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
int main(){
char str1[81],str2[81];
gets(str1);
gets(str2);
int s1=strlen(str1);
int s2=strlen(str2);
int x=max(s1,s2);
for(int i=0;i<x;i++){
str1[i]=toupper(str1[i]);
str2[i]=toupper(str2[i]);
}
int cmp = strcmp(str1,str2);
if(cmp<0)
printf("<\n");
else if (cmp>0)
printf(">\n");
else
printf("=\n");
return 0;
}
运行结果:
此题的加强版本:字符串判等 OpenJ_Bailian - 2743