ITI0011:Trips Traps Trull
Tagasi ITI0011 lehele.
Üldine
Programmikood tuleb kirjutada selliselt, et checkstyle plugin Eclipse'is ei näita vigu.
Tähtaeg: 22. - 26. september (vastavalt rühma tunnile)
Enne seda nädalat esitamine annab +1 lisapunkti.
Tuleb programmeerida Trips-Traps-Trulli mängimiseks käsurea programm ning kasutaja vastu mängiva arvuti strateegia.
Kuna kasutame ülesande testimiseks automaatseid teste, siis oleme ette andnud täpsed funktsioonide nimed. Kui teil jääb midagi arusaamatuks, küsige!
Põhiosa - 5p
Programm kuvab mängulaua ja võimaldab kasutajal mängida arvutiga.
Arvuti mängib "O"-idega, kasutaja "X"-idega.
Näiteks:
+---+---+---+ | O | O | | +---+---+---+ | | X | | +---+---+---+ | | | | +---+---+---+
Kasutaja sisestab käigud mänguruutude indeksitena järgmiselt:
+---+---+---+ | 1 | 2 | 3 | +---+---+---+ | 4 | 5 | 6 | +---+---+---+ | 7 | 8 | 9 | +---+---+---+
Seega, kui kasutaja sisestab "5", siis märgitakse "X" keskmisele ruudule.
Programmi struktuur
Ülesande lahendamisel kasutage laua seisu hoidmiseks ühemõõtmelist massiivi, kus iga ruudu jaoks on üks täisarvuline element. Elemendi väärtus tähistab seda, mis selles ruudus on: 0 - ruut on tühi, 1 - ruudul on kasutaja nupp ("X"), -1 - ruudul on arvuti nupp ("O").
Programm peab sisaldama järgmisi meetodeid (funktsioone):
Funktsioon makeMove, millele antakse ette laua praegune seis ja ta tagastab arvuti ("O") käigu. Sisendina antud massiivis esinevad vaid lubatud väärtused (-1, 0, 1 - vastavalt arvuti nupp, tühi ruut, mängija nupp), ehk siis sisendit kontrollima ei pea.
/** * Takes the current state of the board * and returns the cell index where computer * makes its move. * * The one-dimensional board is indexed as follows: * * +---+---+---+ * | 0 | 1 | 2 | * +---+---+---+ * | 3 | 4 | 5 | * +---+---+---+ * | 6 | 7 | 8 | * +---+---+---+ * * So, the following state: * * +---+---+---+ * | X | | | * +---+---+---+ * | | O | X | * +---+---+---+ * | | | | * +---+---+---+ * * is given as an array: * {1, 0, 0, 0, -1, 1, 0, 0, 0} * where 1 indicates a player stone ("X") and * -1 indicates a computer stone ("O") * * @param board Current state of the board. * See the description of the method for more information. * @return Cell index where the computer makes its move. */ public static int makeMove(int[] board) { // your code here }
Funktsioon readInput, mis loeb klaviatuurilt mängija sisendi ja tagastab saadud numbri. See funktsioon on suures osas teile ette antud. Te peate seda natuke muutma, et ta töötaks õigesti (sisendilugemise osa on korrektne).
/** * Reads a number from the standard input and returns it. * Beware: this method needs some improvements! * @return Number read from the input */ public static int readInput() { Scanner scanner = new Scanner(System.in); if (scanner.hasNextInt()) { int nr = scanner.nextInt(); } scanner.close(); return 0; }
Funktsioon, mis prindib välja lauaseisu (nime võita vabalt valida).
main funktsioonis pange kõik jupid omavahel kokku.
Põhiosa nõuded:
* Kui kasutaja sisend oli ebakorrektne (näiteks polnud number või on liiga suur number (100) vms), antakse sellest kasutajale teada ja küsitakse uut sisendit. * Kui kasutaja poolt sisestatud ruut on juba hõivatud, antakse sellest kasutajale teada ja küsitakse uut sisendit. * Programm võimaldab käike käia kordamööda. Üks mängija ei saa kahte käiku järjest teha. * Peale igat käiku kuvatakse mängulaua seis. * Programm tuvastab, kui mäng on läbi (kõik ruudud on täis - kuhugi enam käia ei saa), ja annab vastava teate. * Arvuti käik võib olla suvaline (kasvõi esimene vaba koht).
Lisa: arvuti eelistatud käigud - 1p
Arvuti eelistab käike:
- kõigepeal keskele
- siis nurkadesse (juhslik (random) valik vabadest nurkadest)
- ülejäänud (juhslik (random) valik vabadest ruutudest)
Selleks täiendada makeMove meetodit vastavalt.
Lisa: võitja tuvastamine - 1p
Programm suudab tuvastada, et mäng on lõppenud - kumbki mängijatest on 3-märki ritta saanud. Teatab mängu võitja.
Selleks kirjutada funktsioon checkWin, mis saab sisendiks mängulaua seisu ja tagastab võitja, kui ühel mängijatest on kolm nuppu reas, või 0, kui kumbki mängija ei ole võitnud (mäng läheb edasi).
/** * Checks the board and returns which player * has winning combination. * @param board The current state of the board * @return The indicator of the player who has winning combination. * If there are no winning combinations, 0 is returned. */ public static int checkWin(int[] board) { // your code here ... }
Lisa: võidukäik - 3p
- Arvuti käib mängu võitva käigu, kui selline laual leidub: arvutil on kaks märki juba reas ja arvuti kord on käia.
- Sarnaselt suudab arvuti blokeerida Kasutaja võitvat käiku: kasutajal on kaks märki juba reas, aga arvuti kord on käia.