请教Python高手几个简单的python代码问题

 我来答
千锋教育
2017-06-29 · 做真实的自己 用良心做教育
千锋教育
千锋教育专注HTML5大前端、JavaEE、Python、人工智能、UI&UE、云计算、全栈软件测试、大数据、物联网+嵌入式、Unity游戏开发、网络安全、互联网营销、Go语言等培训教育。
向TA提问
展开全部

用递归方法求一个已知集合,比如(a,b,a,c),的所有子集

def getsubset(myset,subtract):
  if len(myset)<=1:
    return []
  result=[]
  newsubtract=subtract.copy()
  for i in subtract:
    result.append(myset-{i})
    newsubtract=newsubtract-{i}
    result.extend(getsubset(myset-{i},newsubtract))
  return result
def subset(myset):
  result=[set(),myset] if myset else [myset]
  result.extend(getsubset(myset,myset))
  return result
result=subset({'a','b','c','d'})
toprint=[sorted(x) for x in result]
for i in sorted(toprint,key=lambda x:(len(x),x)):
  print(i)

而且(a,b,a,c) 不是集合,集合中元素不应有重复

一个n个元素的集合的所有子集是2的n次方个吗,如是,这个程序应该就是正确的

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式