Main Page | Class Hierarchy | Class List | File List

solutionhash.h

00001 /***************************************************************************
00002  *   Copyright (C) 2005 by Torben Nielsen   *
00003  *   torben@t-hoerup.dk   *
00004  *                                                                         *
00005  *   This program is free software; you can redistribute it and/or modify  *
00006  *   it under the terms of the GNU General Public License as published by  *
00007  *   the Free Software Foundation; either version 2 of the License, or     *
00008  *   (at your option) any later version.                                   *
00009  *                                                                         *
00010  *   This program is distributed in the hope that it will be useful,       *
00011  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00012  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
00013  *   GNU General Public License for more details.                          *
00014  *                                                                         *
00015  *   You should have received a copy of the GNU General Public License     *
00016  *   along with this program; if not, write to the                         *
00017  *   Free Software Foundation, Inc.,                                       *
00018  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
00019  ***************************************************************************/
00020 #ifndef SOLUTIONHASH_H
00021 #define SOLUTIONHASH_H
00022 
00023 #include "solutioncontainer.h"
00024 #include "solution.h"
00025 
00026 #include <list>
00027 
00028 
00032 class SolutionHash : public SolutionContainer
00033 {
00034 private:
00035     static const int max_size = 256;
00036     typedef std::list<Solution>::iterator ListIt;
00037     typedef std::list<Solution> SolList;
00038      
00039     SolList* solutions[max_size];
00040     
00041     void uniqueSolutionsWorker(int bucket, int rot, bool mirror);
00042     int total;
00043     bool unique;
00044     int m_hashroof;
00045     int m_size;
00046 
00047 public:
00048     SolutionHash();
00049 
00050     ~SolutionHash();
00051     void uniqueSolutions();
00052     int numSolutions();
00053     int totalSolutions();
00054     
00055     Solution solution(int index);
00056     void addSolution(Solution sol);
00057 };
00058 
00059 #endif

Generated on Sun Aug 14 15:33:57 2005 for queensgui.kdevelop by  doxygen 1.3.9.1