首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >这个Python程序生成将n=3表示为正整数和的所有可能的唯一方法的逻辑错误是什么?

这个Python程序生成将n=3表示为正整数和的所有可能的唯一方法的逻辑错误是什么?
EN

Stack Overflow用户
提问于 2022-11-21 08:00:55
回答 1查看 45关注 0票数 0

生成将n=3表示为正整数和的所有可能的唯一方法的Python程序:

代码语言:javascript
复制
def fun():
    res=[]
    a=[]
    def backtracking(n):
        if(n==0):
            res.append(a)
            print(res)
            return
        if(n<0):
            return
        for i in range(1,n+1):
            a.append(i)
            backtracking(n-i)
            a.pop()
    backtracking(3)
    return res

print(fun())  

期待res = [[1,1,1][1,2][2,1][3]]而不是[ [] [] [] [] ]

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-11-21 08:05:36

如果将列表a直接追加到res,则应该追加列表a的副本。列表是通过引用传递的,因此最终,您的res有4个对相同列表的引用,该列表为空。要获得列表的副本,您有不同的选项-- list.copy()copy.copy()方法,或者只是切片list[:]

代码语言:javascript
复制
def fun():
    res=[]
    a=[]
    def backtracking(n):
        if(n==0):
            res.append(a.copy())  # updated
            # print(res)
            return
        if(n<0):
            return
        for i in range(1,n+1):
            a.append(i)
            backtracking(n-i)
            a.pop()
    backtracking(3)
    return res

print(fun())

输出:

代码语言:javascript
复制
[[1, 1, 1], [1, 2], [2, 1], [3]]
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74515786

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档