输入上半部分的行数来打印出一个菱形,例如:
#include
void printLine(int n, int i)
int j;
// 打印当前行的空格
for (j = 1; j <= n-i; j++)
printf(" ");
// 打印当前行的星号
for (j = 1; j <= 2*i-1; j++)
printf("*");
printf("\n");
if (i < n)
printLine(n, i+1);
// 打印下半部分
if (i > 1)
// 打印当前行的空格
for (j = 1; j <= n-i+1; j++)
printf(" ");
// 打印当前行的星号
for (j = 1; j <= 2*i-3; j++)
printf("*");
printf("\n");
int main()
int n;
printf("请输入菱形的长度:");
scanf("%d", &n);
printLine(n, 1);
return 0;
主要思路是:
-
用户输入菱形的长度 n。
-
调用递归函数 printLine,传入 n 和 1,打印第一行。
-
在递归函数中,先打印当前行的空格和星号,然后判断当前行是否为最后一行。
-
如果不是最后一行,递归调用函数,传入 n 和 i+1,打印下一行。
-
如果是最后一行,直接返回。
-
在递归函数的结尾,如果当前行 i 大于 1,说明需要打印菱形的下半部分。这里使用了一个类似的循环来打印下半部分的每一行。
需要注意的是,在打印下半部分时,空格数和星号数与上半部分略有不同,详见程序中的注释。