5.3
本题要求实现函数输出n行数字金字塔。
函数接口定义:
void pyramid( int n );
其中n是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n行数字金字塔。注意每个数字后面跟一个空格。
裁判测试程序样例:
#include <stdio.h>
void pyramid( int n );
int main()
{
int n;
scanf("%d", &n);
pyramid(n);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
5
输出样例:
1
2 2
3 3 3
4 4 4 4
5 5 5 5 5
代码示例:
void pyramid( int n ){
int i,a;
//变量i控制金字塔层数循环输出
//变量a控制每一行前面的空格及后面数字循环输出
for(i=1;i<=n;i++){
for(a=0;a<n-i;a++){ printf(" ");}
//循环输出每一行数字前空格(每一行空格数=总层数-当前层数(n-i) )
for(a=0;a<i;a++){ printf("%d ",i);}
//每一行字母数=层数(i)
printf("\n");
//转行
}
}
思路:
仔细观察金字塔结构,每一行的数字个数与行数一致且与所在层数一致,每一行开头,左边均有总层数-当前层数个空格,空格后接数字+空格结构,右边转入下一行即可。
所以可以设置两个变量,变量i循环用以遍历层数,每一次i循环可以理解成在进行每一行的输出打印,在每一行的输出时,先输出空格,再输出数字(记得加空格),然后转行,所以两次输出均可以通过变量a嵌套在i循环里的for循环实现,但要注意范围,理清当前行数数字左边空格的数量和数字的数量。