求助一下
本题要求实现函数输出n行数字金字塔。函数接口定义:
void pyramid( int n );
其中n是用户传入的参数,为的正整数。要求函数按照如样例所示的格式打印出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) {
for (int i = 1; i <= n; i++) { // 外层循环控制行数
for (int j = 1; j <= n - i; j++) { // 内层循环控制每行数字前面的空格
printf(" ");
}
for (int j = 1; j <= 2 * i - 1; j++) { // 内层循环控制每行数字的输出
printf("%d ", i);
}
printf("\n"); // 每行输出完毕后换行
}
}
在主函数中调用该函数即可实现输出金字塔。
页:
[1]