浙大版《C语言程序设计(第4版)》题目集 习题5-8 空心的数字金字塔
作者:互联网
题目详情:
本题要求实现一个函数,输出n行空心的数字金字塔。
函数接口定义:
void hollowPyramid( int n );
其中n
是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n
行空心的数字金字塔,请注意,最后一行的第一个数字前没有空格。
裁判测试程序样例:
#include <stdio.h>
void hollowPyramid ( int n );
int main()
{
int n;
scanf("%d", &n);
hollowPyramid ( n );
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
5
结尾无空行
输出样例:
1
2 2
3 3
4 4
555555555
结尾无空行
思路:
本题难点在于前(n-1)行数字之前、之间有空格,但末尾无空格,最后一行数字无空格。需要寻找不同行空格数与行数和总行数之间的关系。另外注意该自定义函数无返回值,类型定义为void。若声明函数时不进行定义,编译器会默认为int类型。
个人解答:
void hollowPyramid(int n)
{
int i, row=1; //row记录行数
for( ; row<=n; row++ ){
for( i=1; i<=n-row; i++ ){
printf(" ");
} //输出数字前空格,共n-row个
if(row==1)
printf("1"); //第一行只有1个数字,单独输出
else if(row>1&&row<n){
printf("%d", row); //输出中间某行第一个数字
for(i=1; i<=2*row-3; i++){
printf(" ");
} //输出两数字之间空格,共2row-3项
printf("%d", row); //输出中间某行第二个数字
}else if(row==n){
for(i=1; i<=2*row-1; i++){
printf("%d", row);
} //输出第n行数字
}
printf("\n");
}
}
标签:数字,int,void,浙大,C语言,空格,hollowPyramid,习题,row 来源: https://blog.csdn.net/XY_2738315141/article/details/120753184