原题如下:
练习5-3 数字金字塔 (15 分)
本题要求实现函数输出n行数字金字塔。
函数接口定义:
void pyramid( int n );
其中n是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n行数字金字塔。注意每个数字后面跟一个空格。
裁判测试程序样例:
#include 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
思路分析:
题目要求:
1:根据输入的n值,输出n行数字,组成一个金字塔
2:每个数字后面都有一个空格
我们观察输出样例:每行第一个数字前的空格是不一样的,但是每行最后数字后只有一个空格。我们想办法寻求每行第一个数字前的空格数和行数的关系。
第一行,1前空格数4
第二行,2前空格数3
第三行,3前空格数2
.........
设行数为n,则第i行第一个数字前的空格数为n-i。
这就好办了,我们应该怎样写呢?
首先要输出指定行数的数字,我们要定义一个变量i,用来统计行数,根据i来输出行。
还有,输出空格数,我们再次定义一个j,我们根据它来输出空格。
同理我们再定义一个k变量来记录每行要输出的数字,我们根据它来输出数字。在输出每行数字最后,紧接着加空格。
我们这样就很清楚了。来上代码。 我们给出题目要求的接口函数
下面展示一些 内联代码片。
void pyramid( int n ){ int i,j,k; //三层for嵌套 for(i=1;i<=n;i++){//控制行数 for( j=1;j<=n-i;j++){//根据行数输出空格 printf(" ");//输出数字前空格 } for(k=1;k<=i;k++){//根据行数输出数字 printf("%d",i); printf(" ");//输出数字后的空格 } printf("\n"); } }
完整的代码
下面展示一些 内联代码片。
#include <stdio.h> void pyramid( int n ); int main() { int n; scanf("%d", &n); pyramid(n); return 0; } void pyramid( int n ){ int i,j,k; //下面是三层for for(i=1;i<=n;i++){ for( j=1;j<=n-i;j++){ printf(" ");//输出空格 } for(k=1;k<=i;k++){//行数和数字数目相同的。 printf("%d",i); printf(" "); } printf("\n");//注意换行 } }
测试: