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++代码)(典型的约瑟夫环——链表解决)浏览:1215 |
上车人数 (C语言代码)浏览:1180 |
C语言训练-排序问题<2> (C++代码)(sort函数)浏览:1580 |
【金明的预算方案】 (C++代码)浏览:843 |
剪刀石头布 (C语言代码)浏览:753 |
母牛的故事 (C语言代码)浏览:715 |
母牛的故事 (C语言代码)浏览:551 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:689 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:547 |
简单的a+b (C语言代码)浏览:830 |