本题要求实现函数输出 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
来源:
来源:PTA | 程序设计类实验辅助教学平台
链接:https://pintia.cn/problem-sets/12/exam/problems/300
提交:
题解:
/*
* 数字金字塔
*/
void pyramid(int n) {
for (int i = 1; i <= n; i++) {
// 每行最先输出n-i个空格
for (int j = 1; j <= n - i; j++) {
printf(" ");
}
// 后续接着按输出一个数字,输出一个空格进行循环
for (int k = 1; k <= i; k++) {
printf("%d", i);
printf(" ");
}
printf("\n");
}
}