1241: 画画
时间限制: 1 Sec 内存限制: 128 MB
提交: 1148 解决: 705
[提交] [状态] [讨论版] [命题人:外部导入]
题目描述
初始矩阵(在第1秒)
[a,b]
[c,d]
每一秒一次操作,将当前矩阵向右和右下角复制一份,右下角大小写字母对换。
输入
一个数字n,1<=n<=6
样例输入 Copy
2
样例输出 Copy
a b a b c d c d A B C D
import java.util.Scanner;
//1241
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int n = scanner.nextInt();
// 示例输入
drawPainting(n);
}
private static void drawPainting(int n) {
int size = (int) Math.pow(2, n);
char[][] matrix = new char[size][size];
// 初始化矩阵
for (int i = 0; i < size; i++) {
for (int j = 0; j < size; j++) {
matrix[i][j] = ' ';
}
}
// 初始矩阵
matrix[0][0] = 'a';
matrix[0][1] = 'b';
matrix[1][0] = 'c';
matrix[1][1] = 'd';
// 每一步操作
for (int step = 1; step < n; step++) {
int currSize = (int) Math.pow(2, step);
// 向右复制
for (int i = 0; i < currSize; i++) {
for (int j = 0; j < currSize; j++) {
matrix[i][j + currSize] = matrix[i][j];
}
}
// 向下复制并更改大小写
for (int i = 0; i < currSize; i++) {
for (int j = 0; j < currSize; j++) {
matrix[i + currSize][j + currSize] = toggleCase(matrix[i][j]);
}
}
}
// 打印最终矩阵
for (char[] row : matrix) {
for (char ch : row) {
System.out.print(ch + " ");
}
System.out.println();
}
}
private static char toggleCase(char ch) {
if (Character.isUpperCase(ch)) {
return Character.toLowerCase(ch);
} else {
return Character.toUpperCase(ch);
}
}
}