DFS中append导致列表嵌套的原因是什么?
DFS中append导致列表嵌套的由来
在DFS过程中,为了记录路径,可以使用一个动态数组path来保存经过的节点。在每一次递归中,path都会被修改,因此每次都需要将此时的path复制一份,才能在回溯时还原到之前的状态。
在此代码中,遇到了一个问题:DFS中执行ans.append(path)操作后,ans中存储的结果并不是独立的path列表,而是由path列表组成的列表,即[[path], [path], ...]。
产生嵌套的原因在于ans.append(path)操作将整个path列表作为元素添加到了ans中。当递归回溯时,path列表被修改了,但ans中的列表元素仍然指向了修改前的path,导致ans中的结果相互嵌套。
为了得到正确的独立path列表,需要将ans.append(path)替换为ans.extend(path)。extend操作会将path中的每个元素分别添加到ans中,而不是将整个path列表添加为一个元素。这样,ans中就会存储正确的独立path列表,即[path1, path2, ...]。
-
Python实现字典的key和values的交换
有些时候我们不得已要利用values来反向查询key,有没有简单的方法呢?下面我给大家列举一些方法,方便大家使用pyth...
Python
2个月前 (02-11) 208 -
使用Python脚本来获取Cisco设备信息的示例
今天发现一个使用python写的管理cisco设备的小框架tratto,可以用来批量执行命令。下载后主要有3个文件:Sy...
Python
2个月前 (02-11) 112 -
Python的Django中django-userena组件的简单使用教程
利用twitter/bootstrap,项目的基础模板算是顺利搞定。接下来开始处理用户中心。用户中心主要包括用户登陆、注...
Python
2个月前 (02-11) 100 -
零基础写python爬虫之神器正则表达式
接下来准备用糗百做一个爬虫的小例子。但是在这之前,先详细的整理一下Python中的正则表达式的相关内容。正则表达式在Py...
Python
2个月前 (02-11) 112 -
零基础写python爬虫之抓取百度贴吧代码分享
这里就不给大家废话了,直接上代码,代码的解释都在注释里面,看不懂的也别来问我,好好学学基础知识去! 代码如下:# -*-...
Python
2个月前 (02-11) 100
- 微信三级分销系统产品详情页怎么开发? 4周前 (03-13)
- 微信公众号-获取用户信息(网页授权获取)实现步骤 4周前 (03-13)
- php微信公众号开发(2)百度BAE搭建和数据库使用 4周前 (03-13)
- php微信公众号开发(3)php实现简单微信文本通讯 4周前 (03-13)
- php微信公众号开发(4)php实现自定义关键字回复 4周前 (03-13)
- php版微信小店调用api示例代码 4周前 (03-13)
- php版微信小店API二次开发及使用示例 4周前 (03-13)
- C# 微信公众号开发--准备工作 4周前 (03-13)
- C#微信公众号开发--微信事件交互 4周前 (03-13)
- C#微信公众号开发--网页授权(oauth2.0)获取用户基本信息一 4周前 (03-13)