题目描述
前几天,老师让良哥做一个画空心三角形的程序来取悦小师妹,可把良哥愁死了,C语言基础学得再扎实,算法不精也是硬伤呀!于是良哥又写好了主程序来找机前的你帮忙了^_^
#include <stdio.h>
void holl_triangle(int n); /* 函数声明 */
int main()
{
int n;
scanf("%d", &n); /* 输入行数 n */
holl_triangle(n); /* 调用输入 n 行的空心三角形的函数 */
return 0;
}
输入
输入一个数字,例如 5。
输出
*
* *
* *
* *
*********
根据输入数字,输出空心三角形,如上图为 n=5n=5 时输出的图形。
输入输出样例
样例输入 #1
5
样例输出 #1
*
* *
* *
* *
*********
提示
主程序已给出,请完成 holl_triangle
函数并提交。
思路:
1.
顶端是一个单独的星号,从第二行开始,每行的星号在行的两端,中间是空白,最后一行是满的星号。
2.三角形有 n
行,其中每行的内容和星号位置是动态的,具体如:
包含 n - i - 1
个前导空格,使得三角形居中对齐。
第一个星号在当前行的开始位置。
如果不是最后一行,在行尾也有一个星号,中间部分是空格。
最后一行(即 i = n - 1
)完全由星号组成,没有空格
代码:
#include <stdio.h>
void holl_triangle(int n) {
for (int i = 0; i < n; i++) {
// 打印空格
for (int j = 0; j < n - i - 1; j++) {
printf(" ");
}
// 打印星号
if (i == n - 1) {
// 最后一行,打印全部星号
for (int k = 0; k < 2 * n - 1; k++) {
printf("*");
}
} else {
// 其他行,打印空心部分
printf("*");
for (int k = 0; k < 2 * i - 1; k++) {
printf(" ");
}
if (i > 0) {
printf("*");
}
}
printf("\n");
}
}
int main()
{
int n;
scanf("%d", &n); /* 输入行数 n */
holl_triangle(n); /* 调用输入 n 行的空心三角形的函数 */
return 0;
}
编译结果: