本题要求实现一个函数,输出n行空心的数字金字塔。
void hollowPyramid( int n );
其中n
是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n
行空心的数字金字塔,请注意,最后一行的第一个数字前没有空格。
#include <stdio.h> void hollowPyramid ( int n ); int main() { int n; scanf("%d", &n); hollowPyramid ( n ); return 0; } /* 你的代码将被嵌在这里 */
5
结尾无空行
1 2 2 3 3 4 4 555555555
结尾无空行
本题难点在于前(n-1)行数字之前、之间有空格,但末尾无空格,最后一行数字无空格。需要寻找不同行空格数与行数和总行数之间的关系。另外注意该自定义函数无返回值,类型定义为void。若声明函数时不进行定义,编译器会默认为int类型。
void hollowPyramid(int n) { int i, row=1; //row记录行数 for( ; row<=n; row++ ){ for( i=1; i<=n-row; i++ ){ printf(" "); } //输出数字前空格,共n-row个 if(row==1) printf("1"); //第一行只有1个数字,单独输出 else if(row>1&&row<n){ printf("%d", row); //输出中间某行第一个数字 for(i=1; i<=2*row-3; i++){ printf(" "); } //输出两数字之间空格,共2row-3项 printf("%d", row); //输出中间某行第二个数字 }else if(row==n){ for(i=1; i<=2*row-1; i++){ printf("%d", row); } //输出第n行数字 } printf("\n"); } }