如输入D,得到的图案是:
主要解决以下几个问题:
字母的输出:分左右对称两大块编写:
左边字母部分:从A开始每行递减 for(k=‘A';i<=第几行输出几个,即循环的次数即外循环的i,i++)
右边字母部分(重难点):首先发现输出是
A
BA
CBA ,第一行是没有输出字母的。这里面很好的利用了循环语句先判断执行语句后自增的特点。(第一行)第一次外循环i为A,执行里面语句却没有输出A,说明这里判断不成立。第二行外循环为i为B,却通过判断语句输出了A;第三行输出了BA,说明初始值是左边增完的数值右边递减。说明初始值为i-1,判断条件为是否大于等于A,即for(k=i-1,k>='A';k--)
金字塔的行数:从A至D排序,为行数。循环为for(i='A',i<=D,i++),注意每行输出完换行
空格的输出和字母的输出均放在行数的循环之中
空格的输出:空格的输出第一行输出个数比输入字母比A之差小1,即个数<D-A。第二行,第三行递减,所以D-A需要在每行输出完减1
//编写一个程序,在用户输入某个大写字母后,产生一个金字塔图案。
#include <stdio.h>
int main()
{
char x;
int i=0,k=0,n=0;//i用于表示字母的增加,表示行数,j用于空格的增加,k用于左右分割中间和打印字母
printf("请输入一个大写字母\n");
scanf("%c",&x);
int j=x-64;
printf("输入的数是%c\n",x);
printf("j的值是%d\n",j);
if(x<'A'||x>'Z')
{printf("输入错误,请重新输入");}
else
{
for(i='A';i<=x;i++)//总循环表示行数,
{
for(n=1;n<j;n++)
{
printf(" ");
}
for(k='A';k<=i;k++)
{
printf("%c",k);
}
for(k=i-1;k>='A';k--)
{
printf("%c",k);
}
j--;
printf("\n");
}
}
return 0;
}