小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示(可参见图片)
$
$ $
$
$ $ $ $
$ $ $
$ $ $ $ $ $
$ $ $ $ $
$ $ $ $ $ $ $
$ $ $ $ $ $ $
$ $ $ $ $ $ $
$ $ $ $ $
$ $ $ $ $ $
$ $ $
$ $ $ $
$
$ $
$
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
为了能准确比对空白的数量,程序要求对行中的空白以句点(.)代替。
输入格式
一个正整数 n (n<30) 表示要求打印图形的层数
输出格式
对应包围层数的该标志。
例如:
用户输入:
1
程序应该输出:
.. $..
..$...$..
$
$...$...$
$.$.$
$...$...$
$
..$...$..
..$..
再例如:
用户输入:
3
程序应该输出:
..$..
..$...........$..
$
$...$.......$...$
$.$.$
$.$...$...$...$.$
$.$.$.$.$
$.$.$...$...$.$.$
$.$.$.$.$.$.$
$.$.$...$...$.$.$
$.$.$.$.$
$.$...$...$...$.$
$.$.$
$...$.......$...$
$
..$...........$..
..$..
请仔细观察样例,尤其要注意句点的数量和输出位置。
代码
#include#include char s[150][150]; int main() { int n;//输入 int x = 0, y = 0;//基准点 scanf("%d", &n); for (int i = 0; i < 4 * n + 5; i++) { for (int j = 0; j < 4 * n + 5; j++) { s[i][j] = '.'; } } // 按圈写入 for (int i = 0; i < n + 1; i++) { for (int j = y + 2; j <= y + 4 * (n - i) + 2; j++) s[x][j] = '$'; for (int j = x; j <= x + 2; j++) s[j][y + 2] = '$'; for (int j = x; j <= x + 2; j++) s[j][y + 4 * (n - i) + 2] = '$'; for (int j = y; j <= y + 2; j++) s[x + 2][j] = '$'; for (int j = y + 4 * (n - i) + 2; j <= y + 4 * (n - i) + 4; j++) s[x + 2][j] = '$'; for (int j = x + 2; j <= x + 4 * (n - i) + 2; j++) s[j][y] = '$'; for (int j = x + 2; j <= x + 4 * (n - i) + 2; j++) s[j][y + 4 * (n - i) + 4] = '$'; for (int j = y; j <= y + 2; j++) s[x + 4 * (n - i) + 2][j] = '$'; for (int j = y + 4 * (n - i) + 2; j <= y + 4 * (n - i) + 4; j++) s[x + 4 * (n - i) + 2][j] = '$'; for(int j=x+4*(n-i)+2;j<=x+4*(n-i)+4;j++) s[j][y+2]='$'; for(int j=x+4*(n-i)+2;j<=x+4*(n-i)+4;j++) s[j][y+4*(n-i)+2]='$'; for(int j=y+2;j<=y+4*(n-i)+2;j++) s[x+4*(n-i)+4][j]='$'; x+=2; y+=2; } //输出 for (int i = 0; i < 4 * n + 5; i++) { for (int j = 0; j < 4 * n + 5; j++) { printf("%c", s[i][j]); } printf("n"); } return 0; }
其他方法



