#include <stdio.h>
void main(){
int i,j,k;
for(i=1;i<=9;i++){ //控制输出的行数
for(j=9;j>i;j--){
printf(" "); //控制输出的空格
}
for(k=1;k<=(2*i+1)/2;k++){
printf("%c",48+k);
}
for(k=(2*i+1)/2;k>1;k--){
printf("%c",48+k-1);
}
printf("\n");
}
}
输出结果为:
总结:上图可以看出金字塔 中间的数为对称轴,两边的数是对称的,先输出金字塔左边的数字,(2*i+1)/2是金字塔左边每行数字的个数,在输出金字塔右边的数,(2*i+1)/2-1是金字塔右边每行数字的个数,
每行左边的是(2*i+1)/2个数,右边是(2*i+1)/2-1个数 每行左边比右边少一个数 因此最后一个for循环的条件是k>1,
通过 printf("%c",48+k);输出时,左边每一行的最后一个数永远比右边每一行的最后一个数大1,因此输出的时候是 printf("%c",48+k-1);