python练习(7)——构建矩阵,反转矩阵

本文介绍了使用Python进行列表操作及矩阵生成的方法,包括列表扩展、条件生成、矩阵反转等实用技巧,并通过不同方法对比了矩阵转置的效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

# 生成[[1,2,3],[4,5,6],[1,2,3],[4,5,6].......]
lst = [[1,2,3],[4,5,6]]
c = [lst.extend(lst) for j in range(3)]   # 2**n
d = [[1,2,3] if not i&1 else [4,5,6] for i in range(6)]  #/2
print(c)
print(d)

##生成 n * m 矩阵 matrix
m,n = 5,5
print([[0]*m]*n)   # 陷阱

tm = [[0]*m for j in range(n)]
print(tm)

# 封装和解构,加方括号,相当于后面加了一个逗号
[*a] = [[1,2,3],[4,5,6]]     # a = [[1,2,3],[4,5,6]]
*a, = [1,2,3],[4,5,6]     # a = [[1,2,3],[4,5,6]]
*a, = ([1,2,3],[4,5,6])    # a = [[1,2,3],[4,5,6]]
[x,*y] = [1,2]    # x,y = (1,[2])
# 反转矩阵效率 matrix
import datetime
square = [[4,5,6] for i in range(30)]
n = 100000
start = datetime.datetime.now()
for i in range(n):
  #  tm = [[0 for col in range(len(square))] for row in range(len(square[0]))]
    tm = [0] * len(square[0])         # 构建大列表空间 乘法效率更高,列表解析式和append相当
    for i in range(len(tm)):
        tm[i] = [0] * len(square)
    for i in range(len(tm)):
        for j in range(len(tm[0])):
            tm[i][j] = square[j][i]
delta = (datetime.datetime.now() - start).total_seconds()
print(delta)
print(tm)

start = datetime.datetime.now()
for i in range(n):
    chsquare = []
    for i in range(len(square[0])):
        chsquare.append([])
        for j in range(len(square)):
            chsquare[i].append(square[j][i])
delta = (datetime.datetime.now()-start).total_seconds()
print(delta)
print(chsquare)

# 效率低
start = datetime.datetime.now()
for i in range(n):
    chsquare = []
    for row in square:
        for i,val in enumerate(row):
            if len(chsquare) < i+1:
                chsquare.append([])
            chsquare[i].append(val)
delta = (datetime.datetime.now()-start).total_seconds()
print(delta)    
print(chsquare)

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值