原题链接:蓝桥杯基础练习VIP-字符串对比
注意事项:
1.该题目不允许使用gets()函数(在新的C标准中已经废弃),fgets函数会读入'\n'符不是很方便,考虑使用scanf("%s\n%s",&a,&b)。
2.该题目不允许使用strupr()函数,估计是因为考虑到其不是c的标准库函数1,为了增加通用性?因此需要我们自己编写一个字符串转换大写的函数。
解题思路:
s1 首先比较串长,不等,类别为1
s2 否则说明串长相等,再用字符串比较函数strcmp,若两串相等,类别为2
s3 若不等,就将两串内的字符改为大写字母,再用strcmp比较,若相等,类别为3
s4 若仍然不等,类别为4
通过封装字符串转大写函数为my_strtoupr,可以使代码更简洁
/*
Name:字符串分类,不使用strupr和gets()
Copyright: 2024 desenber
Author: desenber
Date: 04/02/24 11:40
Description:给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关系是以下4中情况之一:
1:两个字符串长度不等。比如 Beijing 和 Hebei
2:两个字符串不仅长度相等,而且相应位置上的字符完全一致(区分大小写),比如 Beijing 和 Beijing
3:两个字符串长度相等,相应位置上的字符仅在不区分大小写的前提下才能达到完全一致(也就是说,它并不满足情况2)。比如 beijing 和 BEIjing
4:两个字符串长度相等,但是即使是不区分大小写也不能使这两个字符串一致。比如 Beijing 和 Nanjing
编程判断输入的两个字符串之间的关系属于这四类中的哪一类,给出所属的类的编号
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define STRING_LENGTH 10
char * my_strtoupr(char * s)
{
for(int i = 0; i <= strlen(s) -1; i++)
s[i]= toupper(s[i]);
return s;
}
int main()
{
char s1[STRING_LENGTH +1]={'\0'} , s2[STRING_LENGTH +1]= {'\0'};
scanf("%s\n%s",s1,s2);
if (strlen(s1) != strlen(s2)) printf("1");
else if ( !( strcmp(s1,s2) ) ) printf("2");
else if ( !( strcmp( my_strtoupr(s1) , my_strtoupr(s2) ) ) ) printf("3");
else printf("4");
exit(EXIT_SUCCESS);
}