【C语言】用循环结构输出数字金字塔

#include 
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");
  }
}

输出结果为:

【C语言】用循环结构输出数字金字塔_第1张图片

【C语言】用循环结构输出数字金字塔_第2张图片【C语言】用循环结构输出数字金字塔_第3张图片

总结:上图可以看出金字塔 中间的数为对称轴,两边的数是对称的,先输出金字塔左边的数字,(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);

 

你可能感兴趣的:(c语言)