-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpuzzle.py
executable file
·73 lines (55 loc) · 2 KB
/
puzzle.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
"""
CSC148, Winter 2021
Assignment 2: Automatic Puzzle Solver
==============================
This code is provided solely for the personal and private use of
students taking the CSC148 course at the University of Toronto.
Copying for purposes other than this use is expressly prohibited.
All forms of distribution of this code, whether as given or with
any changes, are expressly prohibited.
Authors: Diane Horton, Jonathan Calver, Sophia Huynh,
Maryam Majedi, and Jaisie Sin.
All of the files in this directory are:
Copyright (c) 2021 Diane Horton, Jonathan Calver, Sophia Huynh,
Maryam Majedi, and Jaisie Sin.
=== Module Description ===
This module contains the abstract Puzzle class.
DO NOT MODIFY ANYTHING IN THIS MODULE.
"""
from __future__ import annotations
from typing import List
class Puzzle:
""""
A full-information puzzle, which may be solved, unsolved,
or even unsolvable. This is an abstract class.
"""
def __init__(self):
self.Puzzle = None
self.SudokuPuzzle = None
def fail_fast(self) -> bool:
"""
Return True if this Puzzle can never be solved.
Note: fail_fast may return False in some situations where
it can't EASILY be determined that the puzzle has no solution.
Override this in a subclass where you can EASILY determine that
this Puzzle can't be solved.
"""
return False
def is_solved(self) -> bool:
"""
Return True iff this Puzzle is in a solved state.
This is an abstract method that must be implemented
in a subclass.
"""
raise NotImplementedError
def extensions(self) -> List[Puzzle]:
"""
Return a list of legal extensions of this Puzzle.
If this Puzzle has no legal extensions, then an empty list
should be returned.
This is an abstract method that must be implemented
in a subclass.
"""
raise NotImplementedError
def extentions(self):
pass