问题描述 小明为某机构设计了一个十字型的徽标(并非红十字会啊),如下所示: ..$$$$$$$$$$$$$.. ..$...........$.. $$$.$$$$$$$$$.$$$ $...$.......$...$ $.$$$.$$$$$.$$$.$ $.$...$...$...$.$ $.$.$$$.$.$$$.$.$ $.$.$...$...$.$.$ $.$.$.$$$$$.$.$.$ $.$.$...$...$.$.$ $.$.$$$.$.$$$.$.$ $.$...$...$...$.$ $.$$$.$$$$$.$$$.$ $...$.......$...$ $$$.$$$$$$$$$.$$$ ..$...........$.. ..$$$$$$$$$$$$$.. 对方同时也需要在电脑dos窗口中以字符的形式输出该标志,并能任意控制层数。 输入格式 一个正整数 n (n<30) 表示要求打印图形的层数。 输出格式 对应包围层数的该标志。 样例输入1 1 样例输出1 ..$$$$$.. ..$...$.. $$$.$.$$$ $...$...$ $.$$$$$.$ $...$...$ $$$.$.$$$ ..$...$.. ..$$$$$.. 样例输入2 3 样例输出2 ..$$$$$$$$$$$$$.. ..$...........$.. $$$.$$$$$$$$$.$$$ $...$.......$...$ $.$$$.$$$$$.$$$.$ $.$...$...$...$.$ $.$.$$$.$.$$$.$.$ $.$.$...$...$.$.$ $.$.$.$$$$$.$.$.$ $.$.$...$...$.$.$ $.$.$$$.$.$$$.$.$ $.$...$...$...$.$ $.$$$.$$$$$.$$$.$ $...$.......$...$ $$$.$$$$$$$$$.$$$ ..$...........$.. ..$$$$$$$$$$$$$.. 提示 请仔细观察样例,尤其要注意句点的数量和输出位置。
import java.util.*;
public class Main {static boolean[][] num;
public static void main(String args[]){
Scanner scan=new Scanner (System.in);
int n=scan.nextInt();
num=new boolean[4*n+5][4*n+5];
int x=0;
int y=2;
while(n>0){
huixing(x,y);
x+=2;
y+=2;
n--;
}
//num.length指有几行
int s=(num.length/2)+1-1;
for(int p=1;p<=2;p++){
num[s+p][s]=true;
num[s-p][s]=true;
num[s][s+p]=true;
num[s][s-p]=true;
}
num[s][s]=true;
for(int i=0;i<num.length;i++)
{
for(int j=0;j<num[i].length;j++){
if(num[i][j]){
System.out.print("$");
}else{
System.out.print(".");
}
}
System.out.println();
}
}
public static void huixing(int i,int j){
for(int x=j;x<=num.length-j-1;x++){//最上面和最下面的$
num[i][x]=true;
num[num.length-1-i][x]=true;
}
num[i+1][j]=true;//第二行和倒数第二行
num[i+1][num.length-1-j]=true;
num[num.length-1-i-1][j]=true;
num[num.length-1-i-1][num.length-1-j]=true;
for(int x=0;x<3;x++){//第三行和倒数第三行
num[i+2][j-x]=true;
num[i+2][num.length-1-j+x]=true;
num[num.length-i-1-2][j-x]=true;
num[num.length-i-1-2][num.length-1-j+x]=true;
}
for(int k=i+3;k<num.length-1-i-2;k++){//中间几行
num[k][i]=true;
num[k][num.length-i-1]=true;
}
}
}