- 本题要求实现函数输出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,j,k;
for(i=1;i<=n;i++){
for(k=n-i-1;k>=0;k--){ //打印空格,注意是n-i-1!
printf(" ");
}
for(j=1;j<=i;j++){
printf("%d ",i); //按照题目格式%d的后面加空格!
}
printf("\n");
}
}
- 运行没错,但是在n>9后,便无法按照题目所给出的格式输出了!