本题要求实现函数输出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
解题思路: 题目中已经给出提示,“注意每个数字后面跟一个空格”,也就是说输出的每一个数字后面都有一个空格,经过观察发现可以看出每行中数字与空格之间的关系,第i行有n-i个空格、i个i。
代码如下:
#include <stdio.h>
void pyramid( int n );
int main()
{
int n;
scanf("%d", &n);
pyramid(n);
return 0;
}
void pyramid( int n ){
for (int i=1;i<=n;i++){
int j=i;
int k=i;
while(n-j>=0){
printf(" ");
j++;
}
while(k>0){
printf("%d ",i);
k--;
}
printf("\n");
}
}
运行结果:
总结:这里要学会观察通式,不要想得太复杂分什么奇数偶数来算,这样是在太麻烦了。写程序要学会找通式,尽量用一个式子来涵盖所有的情况,还要考虑全面,有没有什么意外的情况,遇到之后该怎样去处理,都要写在程序里面)
另外
while(k>0){
printf("%d ",i);
k--;
}
如果这一段代码将printf("%d",i); 中%d后面的空格去掉,输出就会变成: