多组输入,一个整数(2~20),表示输出的行数,也表示组成“X”的反斜线和正斜线长度。
针对每行输入,输出用"*"组成的x型图案。
- 实际上碰到这种规律较强的问题时,我们需要跳出固有的思维,尝试从新的角度去思考问题
- 比如这道题,最好不要计算中间空格的分布规律,这样操作费时费力;大家一定不要陷入一个误区,导致求解陷入困境。
- 比较好的解决方法就是寻找 '*',通过直接查找目标点位置的规律来完成这道题才是正解
以输入n = 7为例,由上图可知,设横轴为x,纵轴为y;
当x = y,或者x + y = n - 1时,屏幕上输出 *,所以我们可以根据这个规律来进行运算。
这种方法的好处是不需要考虑空格的输出的规律,只需要根据交叉线条x的规律来打印即可。
int a = 0;
while (scanf("%d", &a) != EOF)
{
for (int i = 0; i < a; i++) //i为x轴
{
//每次循环输出一个*或者输出一个空格
for (int j = 0; j < a; j++) //j为y轴
{
if (i == j || i + j == a - 1)
printf("*");
else
printf(" ");
}
printf("\n");
}
}