麓崽. 2021-12-28 09:59 采纳率: 92.3%
浏览 21
已结题

对于执行过程一窍不通…

#include <stdio.h>
main( )
{
char b[]="happychris", k;
for (k=0; b[k]; k++)
{
if(b[k]< 'm')b[k]= b[k]-'a'+'A';
printf("%c", b[k]);}}

  • 写回答

3条回答 默认 最新

  • fuill 2021-12-28 10:09
    关注
    happychris
    
    b[0]:h
    k=0  b[k]=h<'m'
    b[0]-'a'+'A'后:H
    
    b[1]:a
    k=1  b[k]=a<'m'
    b[1]-'a'+'A'后:A
    
    b[2]:p
    b[k]>='m'
    
    b[3]:p
    b[k]>='m'
    
    b[4]:y
    b[k]>='m'
    
    b[5]:c
    k=5  b[k]=c<'m'
    b[5]-'a'+'A'后:C
    
    b[6]:h
    k=6  b[k]=h<'m'
    b[6]-'a'+'A'后:H
    
    b[7]:r
    b[k]>='m'
    
    b[8]:i
    k=8  b[k]=i<'m'
    b[8]-'a'+'A'后:I
    
    b[9]:s
    b[k]>='m'
    
    

    测试代码

    
    #include <stdio.h>
    main( )
    {
        char b[]="happychris", k;
        puts(b);
        printf("\n");
        for (k=0; b[k]; k++)
        {
            printf("b[%d]:%c\n",k,b[k]);
            if(b[k]< 'm')
            {
                printf("k=%d  b[k]=%c<'m'\n",k,b[k]);
                b[k]= b[k]-'a'+'A';
                printf("b[%d]-'a'+'A'后:%c\n",k, b[k]);
            }
            else
            {
            printf("b[k]>='m'\n");
            }
            printf("\n");
        }
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 1月5日
  • 已采纳回答 12月28日
  • 创建了问题 12月28日