python顺时针旋转_矩阵使用python中的列表顺时针旋转90度

我试图在

python中顺时针旋转一个3 * 3矩阵90度.

我已经确定[i] [j]处的元素转到[j] [new_i].

这里new_i取决于之前的i,所以我为它做了一个叫做圆减法的函数.

如果我是0则new_i是2

如果我是1那么new_i是1

如果我是2那么new_i是0

执行后,它给了我意想不到的结果.

我已经打印了每次迭代中发生的所有事情.

我无法弄清楚一些元素如何被不同的元素取代.

'''

1 2 3 7 4 1

4 5 6 rotate 90 degrees 8 5 2

7 8 9 9 6 3

'''

def circular_subtraction(i):

new_i = i

if(i==0):

new_i = 2

elif(i==1):

new_i = 1

elif(i==2):

new_i = 0

return new_i

def rotate_clock(matrix):

new_matrix = matrix

for i in range(len(matrix)):

for j in range(len(matrix)):

new_i = circular_subtraction(i)

new_matrix[j][new_i] = matrix[i][j]

print("New element added from {},{} to {},{} ::: {} to {}".format(i+1,j+1,j+1,new_i+1,matrix[i][j],new_matrix[j][new_i]))

for each_row in new_matrix:

print(each_row)

matrix = [[1,2,3],[4,5,6],[7,8,9]]

print("Length of the matrix : ",len(matrix))

for each_row in matrix:

print(each_row)

print()

matrix = rotate_clock(matrix)

输入矩阵是

[1, 2, 3]

[4, 5, 6]

[7, 8, 9]

预期结果是:

[7, 4, 1]

[8, 5, 2]

[9, 6, 3]

结果是:

[7, 4, 1]

[2, 5, 2]

[1, 2, 1]

最佳答案 你可以使用numpy rot90函数:

np.rot90

mat = [[1, 2, 3], [4,5,6,], [7,8,9]]

np.rot90(mat, k=1, axes=(1,0))

k – 表示转数

axes – 表示旋转方向

产量

array([[7, 4, 1],

[8, 5, 2],

[9, 6, 3]])

您的代码中的问题

代码缺少缩进(但假设它们是正确的)

这条线:

new_matrix = matrix

为矩阵变量分配新引用.

在python中,默认值不是按值复制.

您可以使用深拷贝功能:copy.deepcopy(x[, memo])

import copy

def rotate_clock(matrix):

new_matrix = copy.deepcopy(matrix)

要么

def rotate_clock(matrix):

new_matrix = [row[:] for row in matrix]

否则,您对new_matrix所做的每个更改也都在原始矩阵中完成. (因为new_matrix只是对矩阵的引用)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值