source: liacs/pm/backup/menu.cc@ 6

Last change on this file since 6 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: 24.3 KB
RevLine 
[2]1//Programmeermethoden opdracht 3
2//Gemaakt door Rick van der Zwet & Pascal de Vos
3//
4//IVM met versie problemen zult u in clearall() en in de main() de juiste functie moeten commenten
5
6
7
8#include <iostream>
9#include <cstdio>
10#include <ctime>
11#include <climits>
12
13using namespace std;
14
15//
16//Variable voor het 3x+1 programma
17//
18const int MAX = 25;
19
20
21
22//Het maken van een random getal
23int randomgetal(int x) { // tussen 0 en x
24 static int getal = time (NULL) % x;
25 getal = ( 621 * getal + 1 ) % x;
26 return getal;
27}
28
29//
30// === SORTEREN ===
31//
32
33class grootgetal {
34 public:
35 grootgetal();
36 ~grootgetal() { };
37 void vul(int aantal, int deelgetal);
38 void vulrandom(int aantal);
39 bool testop1();
40 bool iseven(int i);
41 bool maal3plus1();
42 void deeldoor2();
43 void vermoedentest();
44 void drukaf();
45 private:
46 int groot[MAX];
47};
48
49grootgetal::grootgetal() {
50 for (int i = 0; i < MAX; i++) {
51 groot[i] = 0;
52 } // end for
53} // end grootgetal::grootgetal
54
55void grootgetal::vul(int deelgetal, int aantal) {
56 for(int i = 0; i < aantal; i++) {
57 groot[i] = deelgetal;
58 } //end for
59} //end grootgetal::vul
60
61void grootgetal::vulrandom(int aantal) {
62 for (int i = 0; i < aantal; i++) {
63 groot[i] = randomgetal(10000);
64 } // end for
65} // end grootgetal::vulrandom
66
67bool grootgetal::iseven(int i) {
68 return(not(groot[i] % 2));
69} // end grootgetal::iseven
70
71void grootgetal::deeldoor2() {
72 int rest = 0;
73 for (int i = MAX - 1; i >= 0; i--) {
74 if (iseven(i)) {
75 groot[i] = groot[i]/2 + rest;
76 rest = 0;
77 }
78 else {
79 groot[i] = groot[i]/2 + rest;
80 rest = 5000;
81 } // end if
82 } // end for
83} // end grootgetal::deeldoor2
84
85bool grootgetal::maal3plus1() {
86 int rest = 1; // Alvast +1
87
88 for(int i = 0; i < MAX; i++) {
89 groot[i] = (groot[i] * 3) + rest;
90 if(groot[i] >= 10000){
91 rest = (groot[i] / 10000);
92 groot[i] = (groot[i] - (rest * 10000));
93 }
94 else {
95 rest = 0;
96 } //end if
97 } //end for
98
99 if (groot[MAX] > 9999) {
100 return (false);
101 }
102 else {
103 return (true);
104 } //end if
105
106} //end grootgetal::maal3plus1
107
108bool grootgetal::testop1() {
109 if (groot[0] == 1) {
110 for (int i = 1; i < MAX - 1; i++) {
111 if (groot[i] != 0) {
112 return (false);
113 } //end if
114 } //end for
115 return (true);
116 }
117 return (false);
118} //end grootgetal::testop1
119
120void grootgetal::vermoedentest() {
121 int aantalintaraties = 1; //aantal keer (3x+1) (/2) noodzakelijk
122 //stap 0 bestaat niet volgens de PM opgave, dus gelijk stap 1.
123 //hoewel strikt genomen aantalintaraties op 0 begint.
124 cout << "Stap ";
125 cout.width(6);
126 cout.fill(' ');
127 cout << aantalintaraties - 1 << ": ";
128 drukaf();
129 cout << endl;
130 //end stap error fix
131
132 while (not(testop1())) {
133
134 if ((aantalintaraties % 100) == 0) {
135 cout << "Stap ";
136 cout.width(6);
137 cout.fill(' ');
138 cout << aantalintaraties << ": ";
139 drukaf();
140 cout << endl;
141 } //end if
142
143 if (iseven(0)) {
144 deeldoor2();
145 }
146 else {
147 maal3plus1();
148 } //end if
149
150 aantalintaraties++;
151
152 } //end while
153 cout << "Totaal aantal intaraties: " << aantalintaraties << endl;;
154} //end grootgetal::vermoedentest()
155
156void grootgetal::drukaf() {
157 cout << groot[MAX - 1];
158 for (int i = MAX - 2; i >= 0; i--) {
159 if (groot[i] > 999) {
160 cout << groot[i];
161 }
162 else if (groot[i] > 99) {
163 cout << "0" << groot[i];
164 }
165 else if (groot[i] > 9) {
166 cout << "00" << groot[i];
167 }
168 else {
169 cout << "000" << groot[i];
170 }//end if
171 } //end for
172} //end grootgetal::drukaf
173
174//
175// === END SORTEREN ===
176//
177
178//
179// == MASTERMIND ===
180//
181
182//Vraag de gebruiker om zijn invoer
183//AantalGetallen_pt = aantal getallen (pointer)
184//AantalKleuren_pt = aantal mogelijkheiden (pointer)
185//Invoer_pt = array met ingevoerde getallen door gebruiker (pointer)
186void MastermindInvoer(int *AantalGetallen_pt, int *AantalKleuren_pt, int *Invoer_pt) {
187 cout << endl << "Plaats gokje: " << endl;
188 int IngevoerdeGetallen = 0;
189 while (IngevoerdeGetallen < *AantalGetallen_pt) {
190 cout << "Voer getal " << (IngevoerdeGetallen + 1) << " (van de " << *AantalGetallen_pt << ") in "
191 << "[0-" << *AantalKleuren_pt << "] (gevolgd door een enter): ";
192 if (cin >> *(Invoer_pt + IngevoerdeGetallen)) {
193 IngevoerdeGetallen++;
194 }
195 else {
196 cout << "Dit is geen (geldig) getal, gelieve een geldig getal invoeren" << endl;
197 cin.clear();
198 cin.ignore(INT_MAX,'\n');
199 } // end if
200 } // end while
201} //end MastermindInvoer
202
203//Bereken of de bebruiker iets goeds ingevoerd heeft
204//AG_pt => AantalGetallen_pt = aantal getallen (pointer)
205//AK_pt => AantalKleuren_pt = aantal mogelijkheiden (pointer)
206//Invoer_pt = array met ingevoerde getallen door gebruiker (pointer)
207//Antwoord_pt = array met antwoorden (pointer)
208//ATA_pt => AantalTekensAanwezig_pt = Aantal tekens aanwezig, maar niet goed geplaatst (pointer)
209//ATJP => AantalTekensGoedePlek_pt = Aantal tekens op de goede plek (pointer)
210
211void MastermindBereken(int *AG_pt, int *ATA_pt, int *ATJP_pt, int *Antwoord, int *Invoer){
212
213 bool HulpArray[*AG_pt]; //array die nodig is bij het testen van de geldigheid van het
214 //gegeven antwoord, als de plek corresponderend met plek in array antwoord true is dan is het
215 //getal nog niet gebruikt voor het antwoord.
216
217 //hulp array op true stellen
218 for (int i = 0; i < *AG_pt; i++) {
219 HulpArray[i] = true;
220 }
221
222 //Gegokte invoer array doorlopen
223 for (int i = 0;i < *AG_pt; i++) { //loop_1
224
225 //debug (invoer + antwoord laten zien)
226 cout << *(Invoer + i) << " antwoord: " << *(Antwoord + i) << endl;
227 //end debug
228
229 if (*(Invoer + i) == *(Antwoord + i)) { //getal op de goede plek
230 (*ATJP_pt)++;
231 HulpArray[i] = false;
232 }
233 } //end loop_1
234 for (int i = 0; i < *AG_pt; i++) { //loop_2
235 if (HulpArray[i]) {
236 for (int j = 0; j < *AG_pt; j++) { //loop_3
237 if ((*(Invoer + i) == *(Antwoord + j)) && (HulpArray[j])) { //getal aanwezig
238 (*ATA_pt)++;
239 HulpArray[j] = false;
240 j = *AG_pt; //uit loop_2 stappen, hij mag namelijk maar 1 keer tellen
241 }
242 } //end loop_3
243 }
244 } //end loop_2
245} //end MastermindBereken
246
247
248//hoofdmodule voor spel mastermind.
249void MastermindMain() {
250
251 //variabelen voor invoer
252 int AantalGetallen = 4; //Aantal getallen dat de code lang is
253 int AantalKleuren = 6; //Aantal mogelijkheden per code teken
254
255 cout << "Geef het aantal getallen ( <20 ) dat u wilt raden (gevolgd door enter): ";
256 if (cin >> AantalGetallen) {
257 if(AantalGetallen > 20) {
258 cout << "Dit is meer als 20" << endl;
259 return;
260 } // end if
261 }
262 else {
263 cout << "Dit is GEEN getal" << endl;
264 return;
265 } // end if
266
267 cout << "Geef het aantal kleuren ( <20 )dat u wilt raden (gevolgd door enter): ";
268 if (cin >> AantalKleuren) {
269 if(AantalKleuren > 20) {
270 cout << "Dit is meer als 20" << endl;
271 return;
272 } // end if
273 }
274 else {
275 cout << "Dit is GEEN getal" << endl;
276 return;
277 } // end if
278
279 int Invoer[AantalGetallen]; //Array waar de invoer van de gebruiker wordt opgeslagen
280
281 //variabelen voor de berekeing
282 bool NogNietGeraden = true; //Waar zolang code (Antwoord) nog niet geraden
283
284 //variabelen voor uitvoer
285 int AantalTekensJuistePlek = 0; //Pinnetje van de juiste kleur op de juiste plek
286 int AantalTekensAanwezig = 0; //Pinnetje van de juiste kleur, maar niet op de goede plek
287
288 //variabelen voor antwoord
289 int Antwoord[AantalGetallen]; //array met gezochte antwoorden
290
291 //antwoord genereren
292 for (int i = 0; i < AantalGetallen; i++) {
293 Antwoord[i] = randomgetal(AantalKleuren);
294
295 //debug (antwoord laten zien)
296 cout << Antwoord[i] << endl;
297 //end debug
298 } //end for
299
300 while (NogNietGeraden) { //gebruiker code laten raden
301
302 MastermindInvoer(&AantalGetallen, &AantalKleuren, Invoer); //gebruikers invoer opvragen
303 MastermindBereken(&AantalGetallen, &AantalTekensJuistePlek, &AantalTekensAanwezig, Antwoord, Invoer); //vergelijking uitvoeren
304
305 //gebruikers resultaat laten zien
306 if (AantalTekensJuistePlek == AantalGetallen) {
307 cout << "Zeer goed, u heeft het goede antwoord geraden, druk op enter om verder te gaan";
308 cin.get();
309 NogNietGeraden = false;
310 }
311 else {
312 cout << "Aantal op de juiste plek: \t" << AantalTekensJuistePlek << endl;
313 cout << "Aantal niet op de juiste plek:\t" << AantalTekensAanwezig << endl;
314 } //end gebruiker code laten raden
315 } // end while
316 return;
317} // end MasterMindMain
318
319//
320// == END MASTERMIND ===
321//
322
323//
324// === SORTEREN GEDEELTE ===
325//
326
327//Een list bestaat uit allemaal vakjes.
328class Vakje {
329 public:
330 Vakje( );
331 int Getal_int; //Waarde van het vakje
332 Vakje * Volgende_Vakje_pt; //Zijn 'rechterbuur'
333 Vakje * Vorige_Vakje_pt; //Zijn 'linkbuur'
334};
335
336Vakje::Vakje() {
337 Getal_int = 0;
338 Volgende_Vakje_pt = NULL;
339 Vorige_Vakje_pt = NULL;
340}
341
342class listvak {
343 public:
344 //default constuctor (NULL pointers)
345 listvak( );
346 //destructor: niks doen
347 ~listvak( ) { };
348 //creer de list van random lengte met randomgetallen
349 void randomlist();
350 //druk de list van links naar rechts af
351 void drukaf_l_r();
352 //druk de list van recht naar links af
353 void drukaf_r_l();
354 //sorteer de list, volgens bubblesort methode
355 int sorteren();
356 //merge L1 en L2 met opvolgend principe
357 void merge(listvak * L1, listvak * L2);
358 //vernietig de list.
359 void vernietig();
360 private:
361 Vakje * Eerste_Vakje_pt; //pointer naar het eerste vakje
362 Vakje * Laatste_Vakje_pt; //pointer naar het laatste vakje
363};
364
365listvak::listvak( ) {
366 Eerste_Vakje_pt = NULL;
367 Laatste_Vakje_pt = NULL;
368}
369
370//voeg een AantalGetallen_int getallen toe aan de List die door Lbgin wordt gepointerd.
371void listvak::randomlist() {
372 Vakje * VakjeNew_Vakje_pt;
373
374 for (int i = 0; i < randomgetal(1000); i++) {
375 VakjeNew_Vakje_pt = new Vakje;
376 VakjeNew_Vakje_pt->Getal_int = randomgetal(10000);
377 if (Eerste_Vakje_pt != NULL) {
378 VakjeNew_Vakje_pt->Volgende_Vakje_pt = Eerste_Vakje_pt;
379 VakjeNew_Vakje_pt->Volgende_Vakje_pt->Vorige_Vakje_pt = VakjeNew_Vakje_pt;
380 }
381 else {
382 Laatste_Vakje_pt = VakjeNew_Vakje_pt;
383 } //end if
384
385 Eerste_Vakje_pt = VakjeNew_Vakje_pt;
386 } //end for
387} //end listvak::randomlist
388
389//druk de list af van links naar rechts
390void listvak::drukaf_l_r() {
391 Vakje * Hulp_Vakje_pt = Eerste_Vakje_pt;
392 while (Hulp_Vakje_pt != NULL) {
393 cout << Hulp_Vakje_pt->Getal_int << " ";
394 Hulp_Vakje_pt = Hulp_Vakje_pt->Volgende_Vakje_pt;
395 } //end while
396} //end listvak::drukaf_lr
397
398//druk de list af van rechts naar links
399void listvak::drukaf_r_l() {
400 Vakje * Hulp_Vakje_pt = Laatste_Vakje_pt;
401 while (Hulp_Vakje_pt != NULL) {
402 cout << Hulp_Vakje_pt->Getal_int << " ";
403 Hulp_Vakje_pt = Hulp_Vakje_pt->Vorige_Vakje_pt;
404 } //end while
405} //end listvak::drukaf_rl
406
407//sorteren volgens de bubblesort methode (grootste getal achteraan)
408//uitvoer: aantal verwisselingen die plaatsgevonden hebben.
409int listvak::sorteren() {
410 int Verwisselingen_int = 0;
411 Vakje * BubbleHulp_Vakje_pt = Eerste_Vakje_pt; //Dit is het vakje dat gechecked wordt
412 Vakje * BubbleStop_Vakje_pt = Laatste_Vakje_pt; //Hierna hoeft niet meer gechecked worden
413 Vakje * BubbleVakA_Vakje_pt;
414 Vakje * BubbleVakB_Vakje_pt;
415 Vakje * BubbleVakC_Vakje_pt;
416 Vakje * BubbleVakD_Vakje_pt;
417
418 //geen waardes dus gelijk stoppen
419 if (Laatste_Vakje_pt == NULL) {
420 return(0);
421 }
422
423 while (BubbleStop_Vakje_pt->Vorige_Vakje_pt != NULL) {
424 while ( BubbleHulp_Vakje_pt != BubbleStop_Vakje_pt ) {
425 if (BubbleHulp_Vakje_pt->Getal_int > BubbleHulp_Vakje_pt->Volgende_Vakje_pt->Getal_int) {
426 /* Methode voor het omwisselen van vak B en C
427 * Oude situtatie
428 * ___________________________________
429 * | Vorige | Vak Nummer | Volgende |
430 * |========|=============|===========|
431 * | | A | 1->B |
432 * | 2->A | B | 3->C |
433 * | 4->B | C | 5->D |
434 * | 6->C | D | |
435 * ------------------------------------
436 *
437 * Nieuwe situatie
438 * ___________________________________
439 * | Vorige | Vak Nummer | Volgende |
440 * |========|=============|===========|
441 * | | A | 1->C |
442 * | 2->C | B | 3->D |
443 * | 4->A | C | 5->B |
444 * | 6->B | D | |
445 * ------------------------------------
446 *
447 * Uitzondering betreft als A de pointer in het begin is of als
448 * D de eind pointer is.
449 */
450 BubbleVakA_Vakje_pt = BubbleHulp_Vakje_pt->Vorige_Vakje_pt;
451 BubbleVakB_Vakje_pt = BubbleHulp_Vakje_pt;
452 BubbleVakC_Vakje_pt = BubbleHulp_Vakje_pt->Volgende_Vakje_pt;
453 BubbleVakD_Vakje_pt = BubbleHulp_Vakje_pt->Volgende_Vakje_pt->Volgende_Vakje_pt;
454
455 //Pointer 1,2
456 if (BubbleVakA_Vakje_pt == NULL) {
457 Eerste_Vakje_pt = BubbleVakC_Vakje_pt;
458 BubbleVakC_Vakje_pt->Vorige_Vakje_pt = NULL;
459 }
460 else {
461 BubbleVakA_Vakje_pt->Volgende_Vakje_pt = BubbleVakC_Vakje_pt;
462 BubbleVakC_Vakje_pt->Vorige_Vakje_pt = BubbleVakA_Vakje_pt;
463 } //end if
464
465 //Pointer 3,4
466 BubbleVakB_Vakje_pt->Vorige_Vakje_pt = BubbleVakC_Vakje_pt;
467 BubbleVakC_Vakje_pt->Volgende_Vakje_pt = BubbleVakB_Vakje_pt;
468
469 //Pointer 5,6
470 if (BubbleVakD_Vakje_pt == NULL) {
471 Laatste_Vakje_pt = BubbleVakB_Vakje_pt;
472 BubbleVakB_Vakje_pt->Volgende_Vakje_pt = NULL;
473 BubbleStop_Vakje_pt = BubbleVakB_Vakje_pt;
474 }
475 else {
476 BubbleVakD_Vakje_pt->Vorige_Vakje_pt = BubbleVakB_Vakje_pt;
477 BubbleVakB_Vakje_pt->Volgende_Vakje_pt = BubbleVakD_Vakje_pt;
478 } //end if
479
480 //In het geval dat het vakje van de stop pointer kleiner is als het vakje ervoor,
481 //zal de stop pointer over het nieuwe vakje moeten vallen, anders komt hij het stop
482 //teken nooit tegen.
483 // A B C D
484 // 5 9 7 10
485 // ^ ^
486 // | |Stop pointer
487 // | Huidige Waarde
488 //
489 // ZONDER AANPASSING MET AANPASSING
490 //
491 // A C B D A C B D
492 // 5 7 9 10 5 7 9 10
493 // ^ ^ ^ ^
494 // | |Huidige Waarde | |Huidige Waarde + Stop Pointer
495 // | Stop Pointer |
496 //
497 if (BubbleStop_Vakje_pt == BubbleVakC_Vakje_pt) {
498 BubbleStop_Vakje_pt = BubbleVakB_Vakje_pt;
499 } //end if
500
501 Verwisselingen_int++;
502 }
503 else {
504 BubbleHulp_Vakje_pt = BubbleHulp_Vakje_pt->Volgende_Vakje_pt;
505 } //end if
506 } //end while
507 BubbleHulp_Vakje_pt = Eerste_Vakje_pt;
508 BubbleStop_Vakje_pt = BubbleStop_Vakje_pt->Vorige_Vakje_pt;
509 } //end while
510 return (Verwisselingen_int);
511} //end listvak::sorteren
512
513void listvak::merge(listvak * L1, listvak * L2) {
514 bool Toevoegen_bool = true; //zolang true bestaan er nog waardes die toegevoegd moeten worden
515
516 Vakje * HulpL1_Vakje_pt = L1->Laatste_Vakje_pt; //pointer die bijhoudt waar we in L1 zijn
517 Vakje * HulpL2_Vakje_pt = L2->Laatste_Vakje_pt; //pointer die bijhoudt waar we in L2 zijn
518
519 Vakje * VakjeNew_Vakje_pt; //pointer bij gebruikt wordt bij het maken van nieuwe vakjes
520
521 while (Toevoegen_bool) {
522 if ((HulpL1_Vakje_pt != NULL) || (HulpL2_Vakje_pt !=NULL)) { //er zijn nog waardes aanwezig
523 VakjeNew_Vakje_pt = new Vakje;
524
525 if (Eerste_Vakje_pt != NULL) {
526 VakjeNew_Vakje_pt->Volgende_Vakje_pt = Eerste_Vakje_pt;
527 VakjeNew_Vakje_pt->Volgende_Vakje_pt->Vorige_Vakje_pt = VakjeNew_Vakje_pt;
528 }
529 else if (Laatste_Vakje_pt == NULL) {
530 Laatste_Vakje_pt = VakjeNew_Vakje_pt;
531 } //end if
532 Eerste_Vakje_pt = VakjeNew_Vakje_pt;
533
534 if ((HulpL1_Vakje_pt != NULL) && (HulpL2_Vakje_pt != NULL)) { //beiden bevatten nog een getal
535 if (HulpL1_Vakje_pt->Getal_int > HulpL2_Vakje_pt->Getal_int) {
536 VakjeNew_Vakje_pt->Getal_int = HulpL1_Vakje_pt->Getal_int;
537 HulpL1_Vakje_pt = HulpL1_Vakje_pt->Vorige_Vakje_pt;
538 }
539 else {
540 VakjeNew_Vakje_pt->Getal_int = HulpL2_Vakje_pt->Getal_int;
541 HulpL2_Vakje_pt = HulpL2_Vakje_pt->Vorige_Vakje_pt;
542 } //end if
543 }
544 else if (HulpL1_Vakje_pt != NULL) { //L2 leeg, enkel waardes uit L1 plakken
545 VakjeNew_Vakje_pt->Getal_int = HulpL1_Vakje_pt->Getal_int;
546 HulpL1_Vakje_pt = HulpL1_Vakje_pt->Vorige_Vakje_pt;
547 }
548 else if (HulpL2_Vakje_pt != NULL) { //L1 leeg, enkel waardes uit L2 plakken
549 VakjeNew_Vakje_pt->Getal_int = HulpL2_Vakje_pt->Getal_int;
550 HulpL2_Vakje_pt = HulpL2_Vakje_pt->Vorige_Vakje_pt;
551 }
552 }
553 else { //alles leeg, 'over en sluiten'
554 Toevoegen_bool = false;
555 } //end if
556 } //end while
557} //end listvak::merge
558
559//vernietig de list
560void listvak::vernietig() {
561 Vakje * Hulp_Vakje_pt;
562 while (Eerste_Vakje_pt != NULL) {
563 Hulp_Vakje_pt = Eerste_Vakje_pt->Volgende_Vakje_pt;
564 delete Eerste_Vakje_pt;
565 Eerste_Vakje_pt = Hulp_Vakje_pt;
566 } //end while;
567 Laatste_Vakje_pt = NULL;
568} //end listvak::vernietig
569
570//
571// === END SORTEREN ===
572//
573
574
575//
576// === MENU GEDEELTE ===
577//
578
579
580//scherm leegmaken, ivm met verschillen tussen DOS en UNIX de juiste commenten
581void clearall() {
582 system("cls"); //maakt scherm leeg in Dos
583 system("clear"); //maakt scherm leeg
584 cin.clear(); //maak invoerbuffer leeg
585 cin.ignore(INT_MAX, '\n'); //alles was nog te wachten staat negeren
586}
587
588
589void SubMenuMasterMind() {
590 MastermindMain();
591} //end SubMenuMasterMind
592
593void SubMenu3keerplus1() {
594 char MenuKeuze = ' ';
595 int lengte, getal;
596 grootgetal BigGetal;
597
598 while (true) {
599 cout << " --------------------- 3x+1 ----------------- " << endl
600 << "Maak een keuze uit de volgende opties: " << endl
601 << "- Bepaal de lengte, random generatie getal (R/r)" << endl
602 << "- Bepaald de lengte, bepaal het getal zelf (Z/z) " << endl
603 << "- Terug naar Het hoofdmenu (T/t) " << endl
604 << " " << endl
605 << "Keuze: "; cin >> MenuKeuze;
606 clearall();
607
608 switch (MenuKeuze) {
609 case 't': case 'T': //Terug naar Hoofdmenu
610 return;
611 break;
612 case 'r': case 'R': //Vul L1 random
613 cout << "Vul het aantal elementen in: ";
614 cin >> lengte;
615 BigGetal.vulrandom(lengte);
616 BigGetal.vermoedentest();
617 break;
618 case 'z': case 'Z': //Vul L2 random
619 cout << "Vul het aantal elementen in: ";
620 cin >> lengte;
621 cout << endl;
622 cout << "Vul het getal in: ";
623 cin >> getal;
624 BigGetal.vul(getal,lengte);
625 BigGetal.vermoedentest();
626 break;
627 default:
628 cout << "GEEN GOEDE INVOER ..." << endl;
629 break;
630 } // end switch
631 } // end while
632} // end Menu3keerplus1
633
634
635void SubMenuSorteren() {
636 char Menukeuze = ' ';
637 listvak L1,L2,L3;
638
639 while (true) {
640 cout << " ------------- Sorteren --------------- " << endl
641 << "Maak een keuze uit de volgende opties: " << endl
642 << "- Vul L1 random (A/a) " << endl
643 << "- Vul L2 random (B/b) " << endl
644 << "- Vul L3 random (C/c) " << endl
645 << "- Vernietig L1 (D/d) " << endl
646 << "- Vernietig L2 (E/e) " << endl
647 << "- Vernietig L3 (F/f) " << endl
648 << "- Bubblesort L1 (G/g) " << endl
649 << "- Bubblesort L2 (H/h) " << endl
650 << "- Bubblesort L3 (I/i) " << endl
651 << "- Merge L1 en L2 naar L3 (J/j) " << endl
652 << "- Hierbij wordt L1,L2 gesorteerd en L3 gewist " << endl
653 << "- Terug naar Algoritmen (T/t) " << endl
654 << " " << endl
655 << "Keuze: "; cin >> Menukeuze;
656 clearall();
657
658 switch (Menukeuze) {
659 case 'a': case 'A': //Vul L1 random
660 L1.randomlist();
661 L1.drukaf_r_l();
662 cout << endl <<endl;
663 break;
664 case 'b': case 'B': //Vul L2 random
665 L2.randomlist();
666 L2.drukaf_r_l();
667 cout << endl << endl;
668 break;
669 case 'c': case 'C': //Vul L3 random
670 L3.randomlist();
671 L3.drukaf_r_l();
672 cout << endl << endl;
673 break;
674 case 'd': case 'D': //Vernietig L1
675 L1.vernietig();
676 cout << "L1 vernietiged" << endl << endl;
677 break;
678 case 'e': case 'E': //Vernietig L2
679 L2.vernietig();
680 cout << "L2 vernietiged" << endl << endl;
681 break;
682 case 'f': case 'F': //Vernietig L3
683 L3.vernietig();
684 cout << "L3 vernietiged" << endl << endl;
685 break;
686 case 'g': case 'G': //Bubblesort L1
687 L1.sorteren();
688 L1.drukaf_l_r();
689 cout << endl << endl;
690 break;
691 case 'h': case 'H': //Bubblesort L2
692 L2.sorteren();
693 L2.drukaf_l_r();
694 cout << endl << endl;
695 break;
696 case 'i': case 'I': //Bubblesort L3
697 L3.sorteren();
698 L3.drukaf_l_r();
699 cout << endl << endl;
700 break;
701 case 'j': case 'J': //Merge L1 en L2 naar L3
702 L1.sorteren();
703 L2.sorteren();
704 L3.vernietig();
705 L3.merge(&L1,&L2);
706 cout << endl << endl;
707 L3.drukaf_l_r();
708 cout << endl;
709 break;
710 case 't': case 'T': //Naar AlgoritmeMenu
711 return;
712 break;
713 default:
714 cout << "GEEN GOEDE INVOER ..." << endl;
715 break;
716 } // end switch
717 } // end while
718} //end SubMenuSorteren
719
720
721void SubMenuAlgoritmen() {
722char Menukeuze = ' ';
723
724 while (true) {
725 cout << " ------------- Algoritmen ------------- " << endl
726 << "Maak een keuze uit de volgende opties: " << endl
727 << "->Sorteren (S/s) " << endl
728 << "->3x+1 (X/x) " << endl
729 << "->Terug naar het Hoofdmenu (T/t) " << endl
730 << " " << endl
731 << "Keuze: "; cin >> Menukeuze;
732 clearall();
733
734 switch (Menukeuze) {
735 case 's': case 'S':
736 SubMenuSorteren();
737 break;
738 case 'x': case 'X':
739 SubMenu3keerplus1();
740 break;
741 case 't': case 'T':
742 return;
743 break;
744 default:
745 cout << "GEEN GOEDE INVOER" << endl
746 << endl;
747 break;
748 } // end switch
749 } // end while
750
751} // end SubMenuAlgoritmen
752
753
754void HoofdMenu() {
755 char Menukeuze = ' ';
756 while (true) { //oneindige loop
757 cout << "-----Hoofdmenu----" << endl
758 << "->Algoritmen (a/A)" << endl
759 << "->Mastermind (m/M)" << endl
760 << "->Stoppen (s/S)" << endl
761 << " " << endl
762 << "Keuze: ";
763 cin >> Menukeuze;
764 clearall();
765
766 switch (Menukeuze) {
767 case 'a': case 'A': //sub menu Algoritmen
768 SubMenuAlgoritmen();
769 break;
770 case 'm': case 'M': //Mastermind
771 SubMenuMasterMind();
772 break;
773 case 's': case 'S': // Stoppen
774 cout << "Goodbye" << endl;
775 return;
776 break;
777 default:
778 cout << "GEEN GOEDE INVOER" << endl
779 << endl;
780 } //end switch
781 } // end while
782} // end HoofdMenu
783
784void IntroScherm() {
785 cout << "---------------------------------------------------" << endl
786 << "| University of Leiden (12-11-2004) |" << endl
787 << "| Programmeermethoden opdracht 3 |" << endl
788 << "| |" << endl
789 << "| Gemaakt door: |" << endl
790 << "| Rick van der Zwet |" << endl
791 << "| Pascal de Vos |" << endl
792 << "| |" << endl
793 << "| |" << endl
794 << "| Getest op: Unix systeem (Sun OS) |" << endl
795 << "| Windows XP (Dev-C++ 4.9.9.0) |" << endl
796 << "| Freebsd 5.2.1-r11 gcc version 3.3.3 |" << endl
797 << "---------------------------------------------------" << endl
798 << endl;
799}
800
801//
802// === END MENU GEDEELTE ===
803//
804
805
806int main() {
807 system("cls"); //maakt scherm leeg in Dos
808 system("clear"); //maakt scherm leeg
809 //geen cin.clear(), blijft ie op hangen
810IntroScherm();
811 HoofdMenu();
812}
813
Note: See TracBrowser for help on using the repository browser.