注意事项:

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


参考资料:1 C语言strlwr()、strupr()与strstr()、strchr()函数

点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论