提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
numpy:求九宫数
前言
近几天,学习numpy,用3X3矩阵,求九宫数。
一、九宫数求法
之前看到过很多网友的九宫数求法。多数是用列表,感觉有点繁琐。近几天,学习numpy,用3X3矩阵,求九宫数。
本人非计算机专业,也与编程专业无关,纯个人爱好,非喜勿喷!
二、使用步骤
1.引入库
引入库,建立列表:
import numpy as np
import random
lst = [x for x in range(1,10)] # 即:lst=[1,2,3,4,5,6,7,8,9]
2.建立循环,求九宫数
所需知识:
- random.shuffle(lst):: shuffle()有人称之为乱序函数。打乱原有的顺序,返回一个随机序列,不产生新列表。
- np.array():建立3X3矩阵。
- sum(axis=0)) :列求和;d.sum(axis=1)) :行求和。
- np.trace(d) 对角线求和。
while True:
random.shuffle(lst) # shuffle:有人称之为乱序函数。打乱原有的顺序,返回一个随机序列。
d = np.array([lst[:3],lst[3:6],lst[6:]])
e = np.fliplr(d) #将data矩阵 在左右方向翻转。
# d.sum(axis=0)) #列求和 # d.sum(axis=1)) #行求和 # np.trace(d) 对角线求和
if (d.sum(axis=0)[0] == d.sum(axis=0)[1] == d.sum(axis=0)[2] == 15 and
d.sum(axis=1)[0] == d.sum(axis=1)[1] == d.sum(axis=1)[2] == 15 and
np.trace(d) == np.trace(e) == 15):
print(d)
总结
代码实现逻辑都比较简单,愿与初学者共同进步!