首先我们来看打印*正方形(空心)
以下是运行结果;
代码示例:
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main() {
int n = 0;
scanf("%d", &n);
for (int i = 0; i < n; i++) {//控制行
for (int j = 0; j < n; j++) {//控制列
if (i == 0 || i == n - 1 || j == 0 || j == n - 1)//控制什么时候输出“* ”和“ ”
printf("* ");
else
printf(" ");
}
printf("\n");
}
}
首行代码可以在VS2022环境下使用scanf等“不安全的”函数(提高代码的可移植性);
其实这道题 可以把打印的图形看成一个由空格和*组成的矩阵
搞清楚什么时候打印“* ”什么时候打印“ ”就行;
这里就要搞清楚这个*矩阵的规律
i==0;i==n-1;j==0;j==n-1可以理解为控制矩阵的四条边;
接下来我们看打印*X团案
以下是运行结果
其实不难看出,上面的两个图案其实就是个n*n矩阵
图1是5行5列,图2是6行6列,这里是把空格和*都算上了
这样的话,*出现的位置不就是这个矩阵的两条对角线了=-=
i==j和i+j==n-1就是*出现的两条对角线对应的位置
代码示例:
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main() {
int n = 0;
scanf("%d", &n);
for (int i = 0; i < n; i++) {\\控制行
for (int j = 0; j < n; j++) {\\控制列
if (i == j || i+j==n-1)\\控制*出现在对角线位置上
printf("*");
else
printf(" ");
}
printf("\n");
}
}