2301_81202136 2023-11-19 18:29 采纳率: 85.7%
浏览 4
已结题

python中的迷宫问题引发的思考

img


在编写过程中发现了这一点,队列popleft后只是少了一个deque和括号,感觉没有队首出队,自认为应该产生空列表

  • 写回答

2条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2023-11-19 21:21
    关注

    【以下回答由 GPT 生成】

    在你的代码中,你使用了popleft()操作来从队列中获取并移除队首元素。然后你打印了队列和移除的元素,但是你没有打印队列的内容再次验证。

    关于你的问题,popleft()操作是用来从deque的左侧移除并返回元素的。当你使用print(queue.popleft())来输出队首元素时,这个元素从队列中被移除了。因此你在打印队列时,你看到的是移除元素后的结果,这就是为什么队列中会少一个deque和括号。

    如果你想得到正确的队列内容,你可以在使用popleft()操作之前,先将队首元素保存在一个变量中,并在打印队列内容之前打印这个变量。

    下面是修改后的代码示例:

    from collections import deque
    
    dirs = [
        lambda x, y: (x+1, y),
        lambda x, y: (x-1, y),
        lambda x, y: (x, y-1),
        lambda x, y: (x, y+1)
    ]
    
    queue = deque()
    queue.append((1, 1, -1))
    
    while len(queue) > 0:
        curNode = queue.popleft()
        removedElement = curNode # 保存队首元素
        print(queue)
        print(removedElement) # 打印队首元素
        for dir in dirs:
            nextNode = dir(curNode[0])
            print(curNode[1])
            print(curNode[2])
            print(nextNode)
    

    另外,你提到了如何在popleft()操作后产生一个空列表。实际上,当所有元素都被移除后,使用popleft()操作会直接抛出IndexError异常,而不是返回一个空列表。因此,你无需担心产生空列表的问题。

    希望这能帮助到你!如果还有其他问题,请随时向我提问。


    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月28日
  • 已采纳回答 11月20日
  • 创建了问题 11月19日

悬赏问题

  • ¥15 打开软件提示错误:failed to get wglChoosePixelFormatARB
  • ¥30 电脑误删了手机的照片怎么恢复?
  • ¥15 (标签-python|关键词-char)
  • ¥15 python+selenium,在新增时弹出了一个输入框
  • ¥15 苹果验机结果的api接口哪里有??单次调用1毛钱及以下。
  • ¥20 学生成绩管理系统设计
  • ¥15 来一个cc穿盾脚本开发者
  • ¥15 CST2023安装报错
  • ¥15 使用diffusionbert生成文字 结果是PAD和UNK怎么办
  • ¥15 有人懂怎么做大模型的客服系统吗?卡住了卡住了