例如:n=3时,包含A,B,C;n=4时,包含A,B,C,D。
矩阵的正中间为n个字母中字典序最大的那个,从这个字母开始,沿着西北、正北、东北、正西、正东、西南、正南、东南八个方向各有一条由大写字母组成的直线。并且直线上的字母按字典序依次减小,直到大写字母A。
矩阵的其它位置用英文句号.填充。
样例输入一
3
样例输出一
A.A.A
.BBB.
ABCBA
.BBB.
A.A.A
样例输入二
4
样例输出二
A..A..A
.B.B.B.
..CCC..
ABCDCBA
..CCC..
.B.B.B.
A..A..A
import java.util.Scanner;
public class 输出米字形 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
char[][] a = new char[2 * n - 1][2 * n - 1];
int tmp1 = 0;
int tmp2 = n-1;
for (int i = 0; i < 2 * n - 1; i++) {//初始化为0
for (int j = 0; j < 2 * n - 1; j++) {
a[i][j] = '0';
}
}
char x = 'A';
for (int i = 0; i <= n - 2; i++) {//前n-2行
for (int j = tmp1; j < 2 * n - 1; j += tmp2) {
a[i][j] = x;
}
if (i == n-2){
for (int j = i+3;j<2*n-1;j++){
a[i][j] = '.';
}
}
x += 1;
tmp1++;
tmp2--;
}
int count = 0;
for (int i = 2*n-2; i >=n; i--) {//上半部分复制给下半部分
for (int j = 0; j < 2 * n - 1; j++) {
a[i][j] = a[count][j];
}
count++;
}
x = 'A';
for (int i = 0;i<2*n-1;i++){//中间行赋值ABCD...
a[n-1][i] = x;
x+=1;
}
x = 'A';
for (int i = 2*n-2;i>=3;i--){//修改到应有的字母,例如CBA
a[n-1][i] = x;
x+=1;
}
for (int i = 0; i < 2 * n - 1; i++) {//输出
for (int j = 0; j < 2 * n - 1; j++) {
if (a[i][j] == '0') {
a[i][j] = '.';
}
System.out.print(a[i][j]);
}
System.out.println();
}
}
}