Python 求最大子集的递归实现

def PowerSetsRecursive(items):  
    """Use recursive call to return all subsets of items, include empty set"""  

    if len(items) == 0:  
        #if the lsit is empty, return the empty list  
        return [[]]  

    subsets = []  
    first_elt = items[0] #first element  
    rest_list = items[1:]  

    #Strategy:Get all subsets of rest_list; for each of those subsets, a full subset list  
    #will contain both the original subset as well as a version of the sebset that contains the first_elt  

    for partial_sebset in PowerSetsRecursive(rest_list):  

        print('partial_sebset=',partial_sebset)
        subsets.append(partial_sebset)  
        next_subset = partial_sebset[:] +[first_elt]  
        subsets.append(next_subset)  
    return subsets  

#f=['a','b','c','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s']

f1=['a','b','c']

g=PowerSetsRecursive(f1)


print(g)
[[], ['a'], ['b'], ['b', 'a'], ['c'], ['c', 'a'], ['c', 'b'], ['c', 'b', 'a']]
posted @   luoganttcc  阅读(332)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示