Description
一般我们用strcmp可比较两个字符串的大小,比较方法为对两个字符串从前往后逐个字符相比较(按ASCII码值大小比较),直到出现不同的字符或遇到‘\0’为止。如果全部字符都相同,则认为相同;如果出现不相同的字符,则以第一个不相同的字符的比较结果为准。但在有些时候,我们比较字符串的大小时,希望忽略字母的大小,例如“Hello”和“hello”,在忽略字母大小写时是相等的。请写一个程序,实现对两个字符串进行忽略字母大小写的大小比较。
要求用一个自定义函数实现忽略大小写的比较过程,用函数的返回值表示比较的结果:若返回值为0表示两个字符串相等;若返回值为1表示第一个字符串比第二个字符串大;若返回值为-1表示第一个字符串比第二个字符串小。
函数定义为:int MyStrCmp(char *pStr1,char *pStr2)
Input
输入数据共有两行,每行一个字符串,字符串中可能包含空格和其它非字母字符,并且每个字符串长度都不超过80个字符。
Output
如果第一个字符串比第二个字符串小,输出一个字符“<”;
如果第一个字符串比第二个字符串大,输出一个字符“>”;
如果两个字符串相等,输出一个字符“=”。
Sample Input
Hello
hello
Sample Output
=
方法一:
#include<stdio.h>
#include<string.h>
int bijiao(char a[100],char b[100])
{
int i=0;
while(a[i]!='\0' && b[i]!='\0'){
if(a[i]==b[i]) i++;
else if(a[i]>b[i]){
if(a[i]>='a' && a[i]<='z' && b[i]>='A' && b[i]<='Z' && a[i]-32==b[i]) i++;
else return 1;
}
else if(a[i]<b[i]){
if(a[i]<b[i]){
if(a[i]>='A' && a[i]<='Z' && b[i]>='a' && b[i]<='z' && a[i]==b[i]-32) i++;
else return -1;
}
}
}
if(a[i]=='\0' && b[i]=='\0') return 0;
else if(a[i]=='\0' && b[i]!='\0') return -1;
else if(a[i]!='\0' && b[i]=='\0') return 1;
}
int main(){
char a[100],b[100];
int n;
gets(a);
gets(b);
n=bijiao(a,b);
if(n==0) printf("=\n");
else if(n==1) printf(">\n");
else if(n==-1) printf("<\n");
}
注意;i=0;
方法二:
#include<stdio.h>
#include<string.h>
int MyStrCmp(char *pStr1,char *pStr2);
int main(){
int n;
char a[85];
char b[85
];
gets(a);
gets(b);
n=MyStrCmp(a,b);
if(n==0) printf("=\n");
else if(n==-1) printf("<\n");
else if(n==1) printf(">\n");
}
int MyStrCmp(char *pStr1,char *pStr2){
int i=0;
while(pStr1[i]!='\0'&& pStr2[i]!='\0'){
if(pStr1[i]==pStr2[i]) i++;
else if(pStr1[i]>pStr2[i]) {
if((pStr1[i]>='a' && pStr1[i]<='z') && (pStr2[i]>='A' && pStr2[i]<='Z') && (pStr1[i]-32)==pStr2[i]){
i++;
}
else return 1;
}
else if(pStr1[i]<pStr2[i]){
if((pStr1[i]>='A' && pStr1[i]<='Z') && (pStr2[i]>='a' && pStr2[i]<='z') && pStr1[i]==(pStr2[i]-32)){
i++;
}
else
return -1;
}
}
if(pStr1[i]=='\0' && pStr2[i]=='\0')
return 0;
else if(pStr1[i]=='\0'&& pStr2[i]!='\0')
return -1;
else if(pStr1[i]!='\0'&& pStr2[i]=='\0')
return 1;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69388.html