用户3198739 2022-04-23 11:27 采纳率: 60%
浏览 33
已结题

python递归全排列输出问题

  1. 使用print进行打印输出结果正常
  2. 将结果添加只全局变量data_1再打印时输出异常
def is_equal(data,left,right):     #判断left到当前right是否有相等的,如果有说明之前已经对这
    for i in range(left,right):       #个进行过全排序了
        if data[i] == data[right]:
            return True
    return False
def rank(data, step):
    global data_1
    if len(data) == step+1:
        print(data)
        #data_1.append(data)
        #问题:这里的data_1最后输出的不是全排列而是一组重复列表
        return
    else:
        for i in range(step, len(data)):
            if is_equal(data,step,i):  #加一个判断
                continue
            else:
                data[step], data[i] = data[i], data[step]
                rank(data, step + 1)
                data[step], data[i] = data[i], data[step]
if __name__ == '__main__':
    data = list("1223")
    data_1=[]
    rank(data, 0)
    print(data_1)

print输出结果

['1', '2', '2', '3']
['1', '2', '3', '2']
['1', '3', '2', '2']
['2', '1', '2', '3']
['2', '1', '3', '2']
['2', '2', '1', '3']
['2', '2', '3', '1']
['2', '3', '2', '1']
['2', '3', '1', '2']
['3', '2', '2', '1']
['3', '2', '1', '2']
['3', '1', '2', '2']

列表输出结果

[['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3'], ['1', '2', '2', '3']]

  • 写回答

1条回答 默认 最新

  • chuifengde 2022-04-23 13:48
    关注

    .append(data.copy())

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 5月1日
  • 已采纳回答 4月23日
  • 创建了问题 4月23日

悬赏问题

  • ¥15 cgictest.cgi文件无法访问
  • ¥20 删除和修改功能无法调用
  • ¥15 kafka topic 所有分副本数修改
  • ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
  • ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
  • ¥40 串口调试助手打开串口后,keil5的代码就停止了
  • ¥15 电脑最近经常蓝屏,求大家看看哪的问题
  • ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
  • ¥50 C++五子棋AI程序编写
  • ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。