/*
打印十字图
小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示(可参见p1.jpg)
图p1
对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。
为了能准确比对空白的数量,程序要求对行中的空白以句点(.)代替。
输入格式:
一个正整数 n (n<30) 表示要求打印图形的层数
输出:
对应包围层数的该标志。* */
import java.util.Arrays;
import java.util.Scanner;
public class PrintTen {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
sc.close();
String[][] map = new String[n * 4 + 5][n * 4 + 5];
// 先让整个图都是"."
for (int i = 0; i < map.length; i++)
Arrays.fill(map[i], ".");
// 打印中间的十字架
int x = n * 2, y = n * 2 + 2;
for (int i = x; i < x + 5; i++) {
map[i][y] = "$";
map[y][i] = "$";
}
for (int i = 0; i < n; i++) {
// 打印四方的直线$
int a = i * 2, b = (i + 1) * 2, c = n * 4 + 5;
for (int j = b; j < c - b; j++) {
map[a][j] = "$";// 上方
map[c - a - 1][j] = "$";// 下方
map[j][a] = "$";// 左方
map[j][c - a - 1] = "$";// 右方
}
// 左上角
map[b][b] = "$";
map[b - 1][b] = "$";
map[b][b - 1] = "$";
// 右上角
map[b][c - b - 1] = "$";
map[b - 1][c - b - 1] = "$";
map[b][c - b] = "$";
// 左下角
map[c - b - 1][b] = "$";
map[c - b][b] = "$";
map[c - b - 1][b - 1] = "$";
// 右下角
map[c - b - 1][c - b - 1] = "$";
map[c - b - 1][c - b] = "$";
map[c - b][c - b - 1] = "$";
}
for (int i = 0; i < map.length; i++) {
for (int j = 0; j < map[i].length; j++) {
System.out.print(map[i][j]);
}
System.out.println();
}
}
}