Python找到所有子集


  • 第三方库
import itertools as it
a = [-1,0,1,2,-1,4]
result = set(it.combinations(a,r=3))

 

def PowerSetsBinary(items):
    N = len(items)
    res =[]
    for i in range(2 ** N):#子集的个数
        combo = []
        for j in range(N):#用来判断二进制数的下标为j的位置的数是否为1
            if (i >> j) & 1: # 判断是否为1
                combo.append(items[j])
        if not combo: continue # 去掉[]
        res.append(combo)
    return res

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM