我的Python狼羊菜脚本在Python 2.6中崩溃

-1 投票
1 回答
1290 浏览
提问于 2025-04-30 09:03

我正在尝试写一个脚本来解决“狼、白菜和山羊”的问题。每次我运行我的代码时,Python都会崩溃。我的代码有什么问题导致它无法正常工作呢?我想让代码运行后,能够打印出解决问题的每一步。

search.py

class Nodes:
    def succ(self, n):
        raise Exception, "Successor undefined"
    def start(self):
        raise Exception, "Start undefined"
    def goal(self, n):
        raise Exception, "Goal undefined"

wolf_cabbage_goat.py

import search # get the interface

def other_side(left_right):
    if left_right == 'left': return 'right'
    elif left_right == 'right': return 'left'

def safe(node):
    # the side without the farmer needs check,
    # the other is safe
    side_without_farmer = other_side(node['farmer'])

    lone_travelers = set(traveler for traveler in node if node[traveler] == side_without_farmer)

    # dangeroos animals
    unsafe = set(['wolf', 'goat']).issubset(lone_travelers) or\
             set(['goat', 'cabbage']).issubset(lone_travelers)
    return not unsafe

class Wolf_Cabbage_Goat(search.Nodes):
    def start(self):
        # farmer, wolf, cabbage, goat on one side
        return { 'farmer': 'left',
                 'wolf': 'left',
                 'goat': 'left',
                 'cabbage': 'left' }

    def goal(self, node):
        # true if all moved to right
        return set(node[i] for i in node) == set(['right'])

    def succ(self, node):
        for traveler in node.keys() + ['']:
            # for all possible travelers, including none

            if traveler == 'farmer':
                continue
            # ignore, we'll deal separately with him

            new_node = node.copy()
            # create a safety copy

            # if somebody wants to travel, and the farmer is on the
            # same side, do it

            if traveler and new_node[traveler] == new_node['farmer']:
                new_node[traveler] = other_side(new_node[traveler])

            # the farmer always travels
            new_node['farmer'] = other_side(new_node['farmer'])

            # after a trip, the new state is ok if no one gets eaten
            if safe(new_node):
                yield new_node

depth_first_search.py

def depth_first_search(problem, node):
    if problem.goal(node): return [node]
    # base case
    for n_succ in problem.succ(node):
        sol = depth_first_search(problem, n_succ)
        if sol:
            # first path is returned
            return [node] + sol

wcg_run.py

import wolf_cabbage_goat
from depth_first_search import *

wcg = wolf_cabbage_goat.Wolf_Cabbage_Goat()
print depth_first_search(wcg, wcg.start())
暂无标签

1 个回答

0

如果你遇到“未解决的引用”这个错误,我觉得可能是因为以下原因:

one_travelers = set(traveler for traveler in node if node[traveler] == side_without_farmer)

# dangeroos animals
unsafe = set(['wolf', 'goat']).issubset(lone_travelers)

你声明了一个叫 one_travelers 的变量,但却使用了 lone_travelers。

在提问的时候,附上错误信息是个好习惯。此外,如果你使用像 PyCharm 这样的好工具,可以避免很多这样的错误(我个人很喜欢 PyCharm)。

撰写回答