本题要求实现函数输出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) //n表示金字塔总共几层
{
int i,j,k; //i表示金字塔的第几层
for(i=1;i<=n;i++)
{
for(j=1;j<=n-i;j++) //打印每层的空格
printf(" ");
for(k=1;k<=i;k++) //打印每层的符号
printf("%d ",i);
printf("\n"); //每层结束后换行
}
}
思路:
1 //4个空格,1个符号“1 ”
2 2 //3个空格,2个符号“2 ”
3 3 3 //2个空格,3个符号“3 ”
4 4 4 4 //1个空格,4个符号“4 ”
5 5 5 5 5 //0个空格,5个符号“5 ”
1.观察图形形状,确定图形有几层,每层空格数和符号数分别多少;
2.定义变量,一般需要定义4个变量,例子中也有给注释;
3.嵌套循环,外层为层数的循环,内层为空格的循换打印和符号的循环打印并列