python怎么找一个矩阵_python – 查找给定矩阵的所有子矩阵

本文介绍了一个Python程序,包括定义ContinSubSeq函数生成连续子序列和getsubmat函数获取矩阵子矩阵。get_all_sub_mat函数通过递归调用生成所有可能的子矩阵。适合理解矩阵操作和递归算法的读者。
摘要由CSDN通过智能技术生成

假设矩阵

Matrix = [

[1,2,3],4,5],[5,6,7]

]

分为3个功能:

def ContinSubSeq(lst):

size=len(lst)

for start in range(size):

for end in range(start+1,size+1):

yield (start,end)

def getsubmat(mat,start_row,end_row,start_col,end_col):

return [i[start_col:end_col] for i in mat[start_row:end_row] ]

def get_all_sub_mat(mat):

rows = len(mat)

cols = len(mat[0])

for start_row,end_row in ContinSubSeq(list(range(rows))):

for start_col,end_col in ContinSubSeq(list(range(cols))):

yield getsubmat(mat,end_col)

运行这个

for i in get_all_sub_mat(Matrix):

print i

或者更简单,放入一个功能:

def get_all_sub_mat(mat):

rows = len(mat)

cols = len(mat[0])

def ContinSubSeq(lst):

size=len(lst)

for start in range(size):

for end in range(start+1,size+1):

yield (start,end)

for start_row,end_row in ContinSubSeq(list(range(rows))):

for start_col,end_col in ContinSubSeq(list(range(cols))):

yield [i[start_col:end_col] for i in mat[start_row:end_row] ]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值