题目描述
根据输入的正整数n(1 米字形由一个(2n-1)*(2n-1)的矩阵组成,矩阵包含从大写A开始的n个字母
例如:n=3时,包含A,B,C; n=4时,包含A.B.C.D。
矩阵的正中间为n个字母中字典序最大的那个,从这个字母开始,沿着西北、正北、东北、正西、正东、西南、正南、东南八个方向各有一条由大写字母组成的直线。并且直线上的字母按字典序依次减小,直到大写字母A。
矩阵的其它位置用英文句号,填充。
样例输入 3
样例输出
A.A.A
. BBB.
ABCBA
.BBB.
A.A. A
import java.util.Scanner;
public class test1 {
public static void main(String[]args) {
Scanner s=new Scanner(System.in);
int n=s.nextInt();
int k=0;
int t=0;
char[][]a=new char[2*n-1][2*n-1];
for(int i=0;i<2*n-1;i++) {
for(int j=0;j<2*n-1;j++) {
a[i][j]=0;
k=n;
}
}
for(int i=0;i<n-1;i++) {
k--;//字符间隔
t=i;//字符所在列数
for(int j=0;j<3;j++) {
a[i][t]=(char)('A'+i);
t+=k;
}
}
for(int i=0;i<n;i++) {//中间一行
a[n-1][i]=(char)('A'+i);
a[n-1][2*n-2-i]=(char)('A'+i);
}
for(int i=0;i<n-1;i++) {
for(int j=0;j<2*n-1;j++) {
if(a[i][j]==0) {//ASCII值为0,则表示为空时,将其赋值为.
a[i][j]='.';
}
}
}
for(int i=0;i<n-1;i++) {//翻转将第0行和第1行的值赋值给第2*n-2-i行,其不变
for(int j=0;j<2*n-1;j++) {
a[2*n-2-i][j]=a[i][j];
}
}
for(int i=0;i<2*n-1;i++) {
for(int j=0;j<2*n-1;j++) {
System.out.print(a[i][j]);
}
System.out.println();
}
}
}