描述
通常咱们用strcmp可比较两个字符串的大小,比较方法为对两个字符串从前日后逐个字符相比较(按ASCII码值大小比较),直到出现不一样的字符或遇到’\0’为止。若是所有字符都相同,则认为相同;若是出现不相同的字符,则以第一个不相同的字符的比较结果为准(注意:若是某个字符串遇到’\0’而另外一个字符串还未遇到’\0’,则前者小于后者)。但在有些时候,咱们比较字符串的大小时,但愿忽略字母的大小,例如"Hello"和"hello"在忽略字母大小写时是相等的。请写一个程序,实现对两个字符串进行忽略字母大小写的大小比较。web
输入
若是第一个字符串比第二个字符串小,输出一个字符"
若是第一个字符串比第二个字符串大,输出一个字符">";
若是两个字符串相等,输出一个字符"="。svg
输出
若是第一个字符串比第二个字符串小,输出一个字符"
若是第一个字符串比第二个字符串大,输出一个字符">";
若是两个字符串相等,输出一个字符"="。code
样例输入
Hello, how are you?
hello, How are you?xml
样例输出
=字符串
注意:字符串结束符号‘\0’ASCII码最小,为0get
上代码string
#include
#include
#include
#include
#define maxn 85
#include
const char* rev = "abcdefghijklmnopqrstuvwxyz";
const char* mag = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
int max(int a1,int a2)//返回更大的长度
{
if(a1
return a1;
}
char small(char ch,char cx)//比较俩字符大小,返回结果,(‘|0的ASCII码最小’)
{ char qwq;
if(ch
else qwq='>';
return qwq;
}
int main()
{
char s[maxn],a[maxn];
gets(s);
gets(a);
int i,j;
char x;
j=max(strlen(s),strlen(a));
for(i=0;i
{
if(a[i]!=s[i])//若俩字符不等
{
if(isalpha(a[i]) && isalpha(s[i]))//若俩字符都是字母
{
if('a'<=s[i] && s[i]<='z') s[i]-=32; //若一方是小写,则转为大写再比较
if('a'<=a[i] && a[i]<='z') a[i]-=32;
if(a[i]==s[i]) ;//若转大小写后同样,则不处理
else //转后仍不同,比较ASCII大小后输出
{
x=small(s[i],a[i]);
printf("%c",x);
return 0;
}
}
else//若不都是字母,则比较大小后输出
{
x=small(s[i],a[i]);
printf("%c",x);
return 0;
}
}
}
printf("=");
return 0;
}