V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
Karsa
V2EX  ›  Python

python运行一个诡异的地方,求指点

  •  
  •   Karsa · 2013-09-19 15:15:46 +08:00 · 3137 次点击
    这是一个创建于 4087 天前的主题,其中的信息可能已经有所发展或是发生改变。
    env :
    Python 2.7.2 (default, Oct 11 2012, 20:14:37)
    [GCC 4.2.1 Compatible Apple Clang 4.0 (tags/Apple/clang-418.0.60)] on darwin

    问题,copyedNode.neighbors.append(copyingNode)这一行会把copyingNode的neighbors同样append一个copyingNode自身,不懂求指教



    class Node():
    index = 0
    neighbors = []
    def __init__ (self, arg) :
    self.index = arg

    def description(self):
    out = []
    out.append (self.index)
    for item in self.neighbors:
    out.append(item.index)
    print (out)

    def allNode (self, checkArray, out) :
    tempNodesArray = self.neighbors[:]
    tempNodesArray.append(self)
    for node in tempNodesArray:
    if node in checkArray:
    pass
    else:
    checkArray.append(node)
    if node in out:
    pass
    else:
    out.append(node)
    node.allNode(checkArray, out)
    def copy(self):
    queue = [self]
    copyNode = Node(self.index)
    nodesMap = {self:copyNode}

    while len(queue) > 0:
    node = queue.pop()
    copyedNode = nodesMap[node]
    for subNode in node.neighbors :
    if subNode in nodesMap :
    copyedNode.neighbors.append(nodesMap[subNode])
    else:
    copyingNode = Node(subNode.index)
    copyedNode.neighbors.append(copyingNode)
    copyingNode.neighbors = []
    nodesMap[subNode] = copyingNode
    queue.append(subNode)
    copyedNode.description()
    return copyNode

    #///////// test code below //////////
    #create nodes in graph
    nodes = []
    for i in range (0, 7) :
    node = Node(i)
    nodes.append(node)

    #create relation ships among all nodes
    for node in nodes:
    tempNodesArray = nodes[:]
    tempNodesArray.remove(node)
    node.neighbors = tempNodesArray

    print("old graph")
    for node in nodes:
    node.description()

    print("new graph")
    newnode = nodes[0].copy()
    3 条回复    1970-01-01 08:00:00 +08:00
    TankyWoo
        1
    TankyWoo  
       2013-09-20 02:41:27 +08:00
    用 gist 重贴一下你的代码吧。

    Python代码没有格式,缩进会要人命的。。。
    Karsa
        2
    Karsa  
    OP
       2013-09-22 17:14:40 +08:00
    Karsa
        3
    Karsa  
    OP
       2013-09-22 17:18:00 +08:00
    唉,第一次在这里使用gist,想着把嵌入代码放上,加个链接的,结果变成这样了。囧~~~
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3430 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 11:25 · PVG 19:25 · LAX 03:25 · JFK 06:25
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.