source: liacs/alg/solitaire/main.cc@ 144

Last change on this file since 144 was 2, checked in by Rick van der Zwet, 15 years ago

Initial import of data of old repository ('data') worth keeping (e.g. tracking
means of URL access statistics)

  • Property svn:executable set to *
File size: 4.6 KB
Line 
1#include <iostream>
2using namespace std;
3
4/*
5
6Een veld
73,3,7,7,7,3,3
833 vakjes
9
10Vakje:
11 3
12 |
132---V---0
14 |
15 1
16*/
17
18const int maxRij = 7;
19const int maxKolom = 7;
20const int maxAantal = 33;
21
22const int hulp[maxRij][2] = {
23 { 2, 3 },
24 { 2, 3 },
25 { 0, 7 },
26 { 0, 7 },
27 { 0, 7 },
28 { 2, 3 },
29 { 2, 3 }
30};
31
32int AantalZetten = 0;
33
34//omdat buren priemgetallen zijn, kan je ze bij elkaar optellen voor een
35//uniek getal
36const bool buurLinks[maxRij][maxKolom] = {
37 { 0, 0, 0, 1, 1, 0, 0 },
38 { 0, 0, 0, 1, 1, 0, 0 },
39 { 0, 1, 1, 1, 1, 1, 1 },
40 { 0, 1, 1, 1, 1, 1, 1 },
41 { 0, 1, 1, 1, 1, 1, 1 },
42 { 0, 0, 0, 1, 1, 0, 0 },
43 { 0, 0, 0, 1, 1, 0, 0 },
44};
45const bool buurRechts[maxRij][maxKolom] = {
46 { 0, 0, 1, 1, 0, 0, 0 },
47 { 0, 0, 1, 1, 0, 0, 0 },
48 { 1, 1, 1, 1, 1, 1, 0 },
49 { 1, 1, 1, 1, 1, 1, 0 },
50 { 1, 1, 1, 1, 1, 1, 0 },
51 { 0, 0, 1, 1, 0, 0, 0 },
52 { 0, 0, 1, 1, 0, 0, 0 },
53};
54const bool buurBoven[maxRij][maxKolom] = {
55 { 0, 0, 0, 0, 0, 0, 0 },
56 { 0, 0, 1, 1, 1, 0, 0 },
57 { 0, 0, 1, 1, 1, 0, 0 },
58 { 1, 1, 1, 1, 1, 1, 1 },
59 { 1, 1, 1, 1, 1, 1, 1 },
60 { 0, 0, 1, 1, 1, 0, 0 },
61 { 0, 0, 1, 1, 1, 0, 0 },
62};
63const bool buurBeneden[maxRij][maxKolom] = {
64 { 0, 0, 1, 1, 1, 0, 0 },
65 { 0, 0, 1, 1, 1, 0, 0 },
66 { 1, 1, 1, 1, 1, 1, 1 },
67 { 1, 1, 1, 1, 1, 1, 1 },
68 { 0, 0, 1, 1, 1, 0, 0 },
69 { 0, 0, 1, 1, 1, 0, 0 },
70 { 0, 0, 0, 0, 0, 0, 0 },
71};
72
73class vakje {
74 public:
75 vakje(void) {
76 gevuld = true;
77 buur[0] = NULL;
78 buur[1] = NULL;
79 buur[2] = NULL;
80 buur[3] = NULL;
81 }
82 vakje * buur[4];
83 bool gevuld;
84};
85
86vakje * spelarray[maxRij][maxKolom];
87vakje * VakjesList[maxAantal];
88
89
90void maakVeld() {
91 vakje * tmpVakje = NULL;
92 for( int i = 0; i < maxRij; i++ ) {
93 for( int j = 0; j < maxKolom; j++ ) {
94 tmpVakje = new vakje;
95 spelarray[i][j] = tmpVakje;
96 };
97 };
98}
99
100void maakBuren() {
101 for( int i = 0; i < maxRij; i++ ) {
102 for( int j = 0; j < maxKolom; j++ ) {
103 if( buurRechts[i][j] ) {
104 spelarray[i][j]->buur[0] = spelarray[i][j+1];
105 }
106 if( buurBeneden[i][j] ) {
107 spelarray[i][j]->buur[1] = spelarray[i-1][j];
108 };
109 if( buurLinks[i][j] ) {
110 spelarray[i][j]->buur[2] = spelarray[i][j-1];
111 };
112 if( buurBoven[i][j] ) {
113 spelarray[i][j]->buur[3] = spelarray[i+1][j];
114 };
115 };
116 };
117}
118
119void initSpeelVelden() {
120 int tmpNummer = 0;
121 for( int i = 0; i < maxRij; i++ ) {
122 for( int j = hulp[i][0]; j < (hulp[i][0] + hulp[i][1]); j++ ) {
123 VakjesList[tmpNummer] = spelarray[i][j];
124 tmpNummer++;
125 };
126 };
127}
128
129void initSpel() {
130 spelarray[3][3]->gevuld = 0;
131}
132
133void printVeld() {
134 int tmpKolom = 0;
135 for( int i = 0; i < maxRij; i++ ) {
136 tmpKolom = 0;
137 for( int j = 0; j < hulp[i][0]; j++ ) {
138 cout << " ";
139 tmpKolom++;
140 };
141 for( int j = 0; j < hulp[i][1]; j++ ) {
142 cout << spelarray[i][tmpKolom]->gevuld;
143 tmpKolom++;
144 };
145 for( int j = 0; j < (maxKolom - hulp[i][0]); j++ ) {
146 cout << " ";
147 };
148 cout << endl;
149 };
150 cout << endl;
151}
152
153bool spelOnmogelijk() {
154 if( (spelarray[0][2]->gevuld == 1) and
155 (spelarray[0][3]->gevuld == 1) and
156 (spelarray[0][4]->gevuld == 1) and
157 (spelarray[1][2]->gevuld == 0) and
158 (spelarray[1][3]->gevuld == 0) and
159 (spelarray[1][4]->gevuld == 0) ) {
160 return(true);
161 }
162 else {
163 return(false);
164 };
165};
166
167long totaal = 0;
168bool afgelopen = false;
169
170void doeZet() {
171 if( spelOnmogelijk() ) {
172 //cout << "Spel onmogelijk" << endl;
173 return;
174 }
175 else if( AantalZetten == 23 ) {
176 cout << "Test " << totaal << endl;
177 printVeld();
178 //afgelopen = true;
179 return;
180 }
181 else {
182 for(int i = 0; i < maxAantal; i++) {
183 for(int zet = 0; zet < 4; zet++) {
184 if( VakjesList[i]->gevuld == 1 ) {
185 if( VakjesList[i]->buur[zet] != NULL ) {
186 if( VakjesList[i]->buur[zet]->gevuld == 1 ) {
187 if( VakjesList[i]->buur[zet]->buur[zet] != NULL ) {
188 if( VakjesList[i]->buur[zet]->buur[zet]->gevuld == 0 ) {
189 VakjesList[i]->buur[zet]->buur[zet]->gevuld = 1;
190 VakjesList[i]->buur[zet]->gevuld = 0;
191 VakjesList[i]->gevuld = 0;
192 AantalZetten++;
193 totaal++;
194 doeZet();
195 AantalZetten--;
196 VakjesList[i]->buur[zet]->buur[zet]->gevuld = 0;
197 VakjesList[i]->buur[zet]->gevuld = 1;
198 VakjesList[i]->gevuld = 1;
199 if( afgelopen ) {
200 return;
201 };
202 };
203 };
204 };
205 };
206 };
207 };
208 };
209 };
210}
211
212int main () {
213 maakVeld();
214 maakBuren();
215 initSpeelVelden();
216 initSpel();
217 doeZet();
218 return 0;
219}
220
Note: See TracBrowser for help on using the repository browser.