下面就是用C语言的for循环写的详细的关于实现星星类菱形的代码,注释分析比较详细,仅供参考,如有错误或可优化的地方,欢迎读者斧正。
画出图像然后把左边空格当成1,方便看和分析。
先考虑前n行,再处理剩下的n-1行。
1111*
111***
11*****
1*******
*********
1*******
11*****
111***
1111*
//VS系列编译器中不用此定义会出现非法错误
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int main()
{
//由菱形几何性质可知中间行的行数即为菱形的半径
int n = 0; //初始化n
printf("请输入星星菱形边长:");
scanf("%d", &n); //输入n
for (int i = 1; i <= n; i++)//定义从第1行到第n行外循环
{
//随着外循环i的增大(行数的增加)n-i依次变小(图中1依次变小)
//与行数变化相反,所以采取递减
//处理左方空白
//当n=5时 上半部分图像如下图,空白用1表示
//根据等差数列
for (int j = n - i; j>=1; j--)
{
printf(" ");
}
for (int k = 1; k <= 2 * i-1 ;k++) //等差数列公式
{
printf("*");
}
printf("\n");//对每行操作后换行
}
// 下面是从第n+1行开始倒序操作
for (int i = n-1; i >=1; i--)//之前处理了n行,所以接下来处理剩下的n-1行
{
for (int j = 1; j <= n-i; j++) // 1*******
{ // 11*****
printf(" "); // 111***
} // 1111*
for (int k = 1; k <= 2 * i-1; k++)
{
printf("*");
}
printf("\n");
}
//以下是另一种解法正序操作,即把剩下的n-1行当做新的序列从1开始
for (int i = 1; i <= n - 1; i++)
{
for (int j = 1; j <= i; j++)
{
printf(" ");
}
//此时要求得行数与对应行星星个数的函数关系
//首(行)项为2n-3,公差为-2(依次递减),规律变化行数为i,则通过等差数列通项公式:通项=首项+公差*(i-1)
//则2*n-3-2*(i-1)=2*n-2*i-1即为i行星星数的通项
for (int k = 1; k <= 2 * n - 2 * i - 1; k++)
{
printf("*");
}
printf("\n");
}
system("pause");
return 0;
}