原题链接:蓝桥杯基础练习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); }
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复