酷代码 AI
菜单
全部AI  /  热门  /  AI写代码神器
服务商

现有 2 n × 2 n ( n ≤ 10 ) 2 n ×2 n (n≤10) 名作弊者站成一个正方形方阵等候 kkksc03 的发落。kkksc03 决定赦免一些作弊者。他将正方形矩阵均分为 4 个更小的正方形矩阵,每个更小的矩阵的边长是原矩阵的一半。其中左上角那一个矩阵的所有作弊者都将得到赦免,剩下 3 个小矩阵中,每一个矩阵继续分为 4 个更小的矩阵,然后通过同样的方式赦免作弊者……直到矩阵无法再分下去为止。所有没有被赦免的作弊者都将被处以棕名处罚。 给出 n n,请输出每名作弊者的命运,其中 0 代表被赦免,1 代表不被赦免。 输入格式 一个整数 n n。 输出格式 2 n × 2 n 2 n ×2 n 的 01 矩阵,代表每个人是否被赦免。数字之间有一个空格。 输入输出样例 输入 #1复制 3 输出 #1复制 0 0 0 0 0 0 0 1 0 0 0 0 0 0 1 1 0 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0 0 0 1 0 0 0 1 0 0 1 1 0 0 1 1 0 1 0 1 0 1 0 1 1 1 1 1

以下是使用 Python 语言解决此问题的代码: ```python def赦免矩阵(n): size = 2 n matrix = [[1] * size for _ in range(size)] 赦免(matrix, 0, 0, size) for row in matrix: for num in row: print(num, end=' ') print() def赦免(matrix, row_start, col_start, size): if size == 1: return half_size = size // 2 for i in range(row_start, row_start + half_size): for j in range(col_start, col_start + half_size): matrix[i][j] = 0 赦免(matrix, row_start, col_start + half_size, half_size) 赦免(matrix, row_start + half_size, col_start, half_size) 赦免(matrix, row_start + half_size, col_start + half_size, half_size) n = int(input()) 赦免矩阵(n) ``` 当您输入`3`时,它将输出与您期望相同的结果。 [2024-11-03 10:30:46 | AI写代码神器 | 247点数解答]

相关提问