Knight's Tour Generator
Tourneys and the Fast Generation and Obfuscation of Closed Knight's Tours
Warnsdorff.h
Go to the documentation of this file.
1 
4 // MIT License
5 //
6 // Copyright (c) 2019 Ian Parberry
7 //
8 // Permission is hereby granted, free of charge, to any person obtaining a copy
9 // of this software and associated documentation files (the "Software"), to
10 // deal in the Software without restriction, including without limitation the
11 // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
12 // sell copies of the Software, and to permit persons to whom the Software is
13 // furnished to do so, subject to the following conditions:
14 //
15 // The above copyright notice and this permission notice shall be included in
16 // all copies or substantial portions of the Software.
17 //
18 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
19 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
20 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
21 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
22 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
23 // FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
24 // IN THE SOFTWARE.
25 
26 #ifndef __Warnsdorf__
27 #define __Warnsdorf__
28 
29 #include "Includes.h"
30 #include "Random.h"
31 #include "Helpers.h"
32 #include "Defines.h"
33 #include "Board.h"
34 
56 
58  private:
60 
61  int RandomClosedWalk(CBoard& b, int start);
62 
63  bool GenerateTour(CBoard& b);
64  bool GenerateTourney(CBoard& b);
65 
66  public:
67  CWarnsdorff(int seed);
68 
69  void Generate(CBoard& b, CycleType t);
70 }; //CWarnsdorff
71 
72 #endif
int RandomClosedWalk(CBoard &b, int start)
Create closed random walk.
Definition: Warnsdorff.cpp:187
Knight's tour and tourney generator using Warnsdorff's heuristic.
Definition: Warnsdorff.h:57
Defines, enumerated types, and typedefs.
void Generate(CBoard &b, CycleType t)
Generate a tour or tourney.
Definition: Warnsdorff.cpp:265
CRandom m_cRandom
PRNG.
Definition: Warnsdorff.h:59
Useful includes.
CWarnsdorff(int seed)
Constructor.
Definition: Warnsdorff.cpp:35
Header for helper functions.
bool GenerateTourney(CBoard &b)
Generate a tourney.
Definition: Warnsdorff.cpp:137
Chessboard.
Definition: Board.h:42
Pseudorandom number generator (PRNG for short).
Definition: Random.h:38
Header for the pseudo-random number generator CRandom.
Header for the chessboard CBoard.
bool GenerateTour(CBoard &b)
Generate a knight's tour.
Definition: Warnsdorff.cpp:44
CycleType
Cycle type.
Definition: Defines.h:58