排列组合用处很多,所以打算自己做个这个工具:
from scipy.special import comb,permfrom os import systemN=int(input('NumberOfThings:'))k=int(input('NumberOfElementsTaken:'))print('从%d里面取出%d个元素:'%(N,k))print('排列:')print(perm(N,k,exact=True))#exact T 返回长整,F返回浮点print('组合:')print(comb(N,k,exact=True))system('pause')
核心就是两句:
from scipy.special import comb,permprint(perm(N,k,exact=True))#exact T 返回长整,F返回浮点print(comb(N,k,exact=True))
真方便,于是跑去用pyinstaller打包......
竟然失败了,若干支持库找不到.........我擦
赶紧写个hello world 打个包,看看是不是pyinstaller炸了.
然而一切正常......
嗯,是的,我遇到了pyinstaller不支持的情况了.
怎么办呢?自己写了一个,实现了浮点数运算,可是我想要的是python的长整型啊!!!!.算了,还是去复制黏贴一下吧....于是打开perm 和 comb的实现部分,开始找代码.好坑,组合居然有个函数引用的是pyd里面的.....,只好原封不动的搬过来了.
于是为了适应pyinstaller的版本出现了:
from _comb import _comb_intdef pailie(N,k): if (k > N) or (N < 0) or (k < 0): return 0 val = 1 for i in range(N - k + 1, N + 1): val *= i return valdef zuhe(N,k): return _comb_int(N, k)while True: ctl='' ctl=input('input 0 to exit,anything else to proceed:') if ctl=='0': break N=int(input('Number of things:')) k=int(input('Number of elements taken')) print('排列:') print(pailie(N,k)) print('组合:') print(zuhe(N,k))
把这个源文件和_comb.cp36-win_amd64.pyd一起从工程里考出来,找个文件夹塞进去,pyinstaller一下......嘿嘿嘿,成功了.整个绿色软件10.6兆,好吧,有点肥.
这样,就有了一个顺手的小工具了,哈哈