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 人评分
WU-C语言程序设计教程(第三版)课后习题11.11 (C++代码)(想学链表的可以看看)浏览:1372 |
The 3n + 1 problem (C语言代码)浏览:563 |
永远的丰碑 (C语言代码)浏览:536 |
1052题解(链表操作)浏览:707 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:647 |
1162答案错误,为什么浏览:655 |
C语言程序设计教程(第三版)课后习题8.9 (C语言代码)浏览:515 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:820 |
C语言程序设计教程(第三版)课后习题6.4 (C语言代码)浏览:1202 |
管理学院的人数 (Java代码)浏览:543 |