C语言——忽略大小写比较字符串大小

版权声明:都是平时的作业 欢迎评论点赞哦 https://blog.csdn.net/Getugly/article/details/86677357

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;
}




猜你喜欢

转载自blog.csdn.net/Getugly/article/details/86677357