我正在尝试编写 python 代码来打印字符串的powerset,但遇到了一些错误。这是我所拥有的:
def getperm (string):
perm = []
if len(string) == 0:
perm.append("")
return perm
#if len(string) == 1:
# perm.append(string)
# perm.append("")
first = string[0]
print "first = " + str(first)
rem = string[1:len(string)]
print "rem = " + str(rem)
words = getperm(rem)
for word in words:
for i in range(len(word)):
temp = string[0:i] + first + string[i:len(string)]
print "temp = " + str(temp)
perm.append(temp)
return perm
if __name__=="__main__":
a = "ab"
mag = getperm(a)
print mag
我的预期输出是:
['', 'a', 'b', 'ab']
我的实际输出是:
[]
谁能帮我弄清楚发生了什么?这是python的一些细微差别,还是我的代码中有错误?我认为我的代码应该没问题——我要离开第五版破解编码面试
谢谢!