markreisen 2022-11-01 21:37 采纳率: 100%
浏览 46
已结题

关于c语言字符串的问题

关于字符串
问题描述
  给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关系是以下4中情况之一:
  1:两个字符串长度不等。比如 Beijing 和 Hebei
  2:两个字符串不仅长度相等,而且相应位置上的字符完全一致(区分大小写),比如 Beijing 和 Beijing
  3:两个字符串长度相等,相应位置上的字符仅在不区分大小写的前提下才能达到完全一致(也就是说,它并不满足情况2)。比如 beijing 和 BEIjing
  4:两个字符串长度相等,但是即使是不区分大小写也不能使这两个字符串一致。比如 Beijing 和 Nanjing
  编程判断输入的两个字符串之间的关系属于这四类中的哪一类,给出所属的类的编号。
输入格式
  包括两行,每行都是一个字符串
输出格式
  仅有一个数字,表明这两个字符串的关系编号
样例输入
BEIjing
beiJing
样例输出
3
我写的代码:

#include<stdio.h>
#include<string.h>
int main()
{
    int i,j;
    char a[100],b[100];
    gets(a);
    gets(b);
    i=0;j=0;
    while(a[i]!='\0')
        i++;
    while(b[j]!='\0')
        j++;
    if(i!=j)
        printf("1");
    else
        {
            if(!strcmp(a,b))
                printf("2");
            else
            {
                i=0;
                while(a[i]!='\0')
                    if(a[i]!=b[i]+32||a[i]!=b[i]-32||a[i]!=b[i])
                        break;
                    else
                        i++;
                if(i==j)
                    printf("3");
                else
                    printf("4");
            }
        }
 } 

为什么在输入beijing
Beijing的时候会输出4呢?

img

  • 写回答

1条回答 默认 最新

  • 叶落花枯 2022-11-01 21:53
    关注

    24行的条件是&&,要同时成立 a[i]!=b[i]+32 && a[i]!=b[i]-32 && a[i]!=b[i]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月10日
  • 已采纳回答 11月2日
  • 创建了问题 11月1日

悬赏问题

  • ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验
  • ¥15 canal如何实现将mysql多张表(月表)采集入库到目标表中(一张表)?
  • ¥15 wpf ScrollViewer实现冻结左侧宽度w范围内的视图
  • ¥15 栅极驱动低侧烧毁MOSFET
  • ¥30 写segy数据时出错3
  • ¥100 linux下qt运行QCefView demo报错
  • ¥50 F1C100S下的红外解码IR_RX驱动问题