Sha256: 91adbda61b87e752e57baecc6c3ce8cde6fd2a5b78e38c2ee3d2377a7bcfa591

Contents?: true

Size: 1.62 KB

Versions: 167

Compression:

Stored size: 1.62 KB

Contents

import copy


class Point(object):
    def __init__(self, x, y):
        self.x = x
        self.y = y

    def __repr__(self):
        return 'Point({}:{})'.format(self.x, self.y)

    def __add__(self, other):
        return Point(self.x + other.x, self.y + other.y)

    def __sub__(self, other):
        return Point(self.x - other.x, self.y - other.y)

    def __eq__(self, other):
        return self.x == other.x and self.y == other.y

    def __ne__(self, other):
        return not (self == other)


DIRECTIONS = (Point(1, 0), Point(1, -1), Point(1, 1), Point(-1, -1),
              Point(0, -1), Point(0, 1), Point(-1, 1), Point(-1, 0))


class WordSearch(object):
    def __init__(self, puzzle):
        self.rows = puzzle.split()
        self.width = len(self.rows[0])
        self.height = len(self.rows)

    def find_char(self, coordinate):
        if coordinate.x < 0 or coordinate.x >= self.width:
            return
        if coordinate.y < 0 or coordinate.y >= self.height:
            return
        return self.rows[coordinate.y][coordinate.x]

    def find(self, word, position, direction):
        current = copy.copy(position)
        for letter in word:
            if self.find_char(current) != letter:
                return
            current += direction
        return position, current - direction

    def search(self, word):
        positions = (Point(x, y)
                     for x in range(self.width) for y in range(self.height))
        for pos in positions:
            for d in DIRECTIONS:
                result = self.find(word, pos, d)
                if result:
                    return result
        return None

Version data entries

167 entries across 167 versions & 1 rubygems

Version Path
trackler-2.2.1.87 tracks/python/exercises/word-search/example.py
trackler-2.2.1.86 tracks/python/exercises/word-search/example.py
trackler-2.2.1.85 tracks/python/exercises/word-search/example.py
trackler-2.2.1.84 tracks/python/exercises/word-search/example.py
trackler-2.2.1.83 tracks/python/exercises/word-search/example.py
trackler-2.2.1.82 tracks/python/exercises/word-search/example.py
trackler-2.2.1.81 tracks/python/exercises/word-search/example.py
trackler-2.2.1.80 tracks/python/exercises/word-search/example.py
trackler-2.2.1.79 tracks/python/exercises/word-search/example.py
trackler-2.2.1.78 tracks/python/exercises/word-search/example.py
trackler-2.2.1.77 tracks/python/exercises/word-search/example.py
trackler-2.2.1.76 tracks/python/exercises/word-search/example.py
trackler-2.2.1.75 tracks/python/exercises/word-search/example.py
trackler-2.2.1.74 tracks/python/exercises/word-search/example.py
trackler-2.2.1.73 tracks/python/exercises/word-search/example.py
trackler-2.2.1.72 tracks/python/exercises/word-search/example.py
trackler-2.2.1.71 tracks/python/exercises/word-search/example.py
trackler-2.2.1.70 tracks/python/exercises/word-search/example.py
trackler-2.2.1.69 tracks/python/exercises/word-search/example.py
trackler-2.2.1.68 tracks/python/exercises/word-search/example.py