打印字母塔

问题:

编写程序,输出以下形状的字母塔:

      A
      ABA
      ABCBA
      ABCDCBA
     ......
    ABCD..Z..DCBA

分析:

求解此问题有两个关键步骤:一是确定每一行前导空格符的数目;二是按照一定的规律输出大写英文字母。显然,一共将输出26行。所编的程序应能保证最后一行的前导控制符数目至少为0,不妨设最后一行有10个前导控制符,那么倒数第二行应有11个前导控制符,倒数第三行有12个,以此类推,第一行应有35个前导控制符。一般的,若令centralch表示“字母塔”某行位于中央垂线上的那一行字符,如上图字符"I",则该行的前导空格符数目应为'Z'-centralch+10,即90-73+10=27,而该行接着输出的一串英文大写字母字符应是由‘A'递增至centralch,然后由centralch-1递减至’A',最后回车换行。由于有固定规律可寻,显见用循环结构,又因为这是确定次数的循环,故易选用for语句。循环控制变量选用字符变量。

 1 #include<stdio.h>
 2 main(){
 3     int i;
 4     char ch,centralch;
 5     printf("\n\n");
 6     for(centralch='A';centralch<='Z';centralch++){
 7         for(i=1;i<='Z'-centralch+10;i++)
 8             printf(" ");
 9         for(ch='A';ch<=centralch;ch++)
10             printf("%c",ch);
11         for(ch=centralch-1;ch>='A';ch--)
12             printf("%c",ch);
13         printf("\n");
14     }
15 } 

 









转载于:https://www.cnblogs.com/geziyu/p/8734851.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值