Sha256: 25d9dcc7db4a078ba7a9f1087f77f8d1c28797b58b5925af2d2bd5709e9eec00

Contents?: true

Size: 1.48 KB

Versions: 71

Compression:

Stored size: 1.48 KB

Contents

"""This solution for the Zebra Puzzle is adapted from a solution
by Peter Norvig for the course "Design of Computer Programs" on Udacity.
https://www.udacity.com/course/cs212
"""

from itertools import permutations


def just_right_of(x, y):
    return x - y == 1


def next_to(x, y):
    return abs(x - y) == 1


def solution():
    houses = first, _, middle, _, _ = range(5)
    orderings = list(permutations(houses))
    result = next(
        [{
            Englishman: "Englishman",
            Spaniard: "Spaniard",
            Ukranian: "Ukranian",
            Japanese: "Japanese",
            Norwegian: "Norwegian"
        }[x] for x in (water, zebra)]
        for (red, green, ivory, yellow, blue) in orderings
        if just_right_of(green, ivory)
        for (Englishman, Spaniard, Ukranian, Japanese, Norwegian) in orderings
        if Englishman is red if Norwegian is first if next_to(Norwegian, blue)
        for (coffee, tea, milk, oj, water) in orderings if coffee is green
        if Ukranian is tea if milk is middle
        for (OldGold, Kools, Chesterfields, LuckyStrike, Parliaments
             ) in orderings if Kools is yellow if LuckyStrike is oj
        if Japanese is Parliaments
        for (dog, snails, fox, horse, zebra) in orderings if Spaniard is dog
        if OldGold is snails if next_to(Chesterfields, fox)
        if next_to(Kools, horse))
    return result


def drinks_water():
    ans, _ = solution()
    return ans


def owns_zebra():
    _, ans = solution()
    return ans

Version data entries

71 entries across 71 versions & 1 rubygems

Version Path
trackler-2.2.1.159 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.158 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.157 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.156 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.155 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.154 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.153 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.152 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.151 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.150 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.149 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.148 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.147 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.146 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.145 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.144 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.143 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.142 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.141 tracks/python/exercises/zebra-puzzle/example.py
trackler-2.2.1.140 tracks/python/exercises/zebra-puzzle/example.py