Accueil Finances personnelles Défi de programmation java: Ajout de tableaux au programme Simple Tic-Tac-Toe

Défi de programmation java: Ajout de tableaux au programme Simple Tic-Tac-Toe

Vidéo: Coding Challenge #3: The Snake Game 2025

Vidéo: Coding Challenge #3: The Snake Game 2025
Anonim

Le défi de programmation Java s'appuie sur les défis précédents de cette série Tic-Tac-Toe et teste votre capacité à utiliser des tableaux - deux d'entre eux, en fait.

Dans Java Programming Challenge: un jeu simple de Tic-Tac-Toe et un défi de programmation Java: Ajouter une classe au programme simple Tic-Tac-Toe, vous êtes invité à écrire un programme pour jouer au jeu simple de Tic-Tac-Toe.

En tant que jeu, Tic-Tac-Toe réclame l'utilisation d'un tableau pour représenter l'état du jeu. Sans tableaux, vous devez utiliser une variable distincte pour représenter chaque carré du tableau. Avec un tableau, vous pouvez utiliser une seule variable pour représenter tous les neuf carrés.

Ce défi de programmation est simple: écrire une version améliorée du programme qui utilise des tableaux. Vous devez utiliser au moins deux tableaux dans votre solution:

  1. Vous devez utiliser un tableau pour représenter le tableau. Très probablement, vous voudrez utiliser un tableau unidimensionnel avec neuf éléments, comme suit:

    0 | 1 | 2 --- | --- | --- 3 | 4 | 5 --- | --- | --- 6 | 7 | 8
    

    En d'autres termes, le carré en haut à gauche (A1) est stocké dans l'élément de tableau 0, et le carré en bas à droite (C3) est stocké dans l'élément de tableau 8.

  2. Vous devez également utiliser un tableau pour représenter les huit vecteurs de trois rangs possibles.

    Vous pouvez ensuite utiliser ce tableau pour déterminer si l'un des joueurs a gagné la partie. Très probablement, vous voudrez utiliser un tableau à deux dimensions pour cette tâche. Le tableau contiendra huit tableaux à trois éléments, chacun représentant les trois indices d'un vecteur particulier à trois rangs.

    Le tableau complet contiendrait les données suivantes:

    0 1 2 3 4 5 6 7 8 0 3 6 1 4 7 2 5 8 0 4 8 2 4 6
    

Une autre exigence de ce programme est que la classe TicTacToeBoard que vous créez pour ce défi doit être complètement compatible avec la classe que vous avez créée pour le défi précédent. En d'autres termes, il doit implémenter exactement les mêmes méthodes. Pour votre commodité, ces méthodes sont répétées dans le tableau suivant.

Parce que ces méthodes se réfèrent aux carrés du tableau tac-tac-toe en utilisant des désignations de lignes-colonnes telles que A1 ou B2, votre implémentation devra mapper ces désignations aux numéros d'index. Par exemple, si la chaîne A1 est passée à la méthode playAt, le programme doit marquer la lecture à l'index 0 dans le tableau.

Le TicTacToeBoard Class
Constructeur Description
TicTacToeBoard

Crée un nouveau TicTacToeBoard avec tous les carrés vides.
Méthode Description
void reset () Réinitialise l'état de chaque carré à vider.
void playAt (Chaîne carrée, int joueur) Marque le carré spécifié (A1, A2, A3, B1, B2, B3, C1, C2 ou C3) pour le joueur spécifié (1 pour X, 2 pour O). Lance IllegalArgumentException si square n'est pas une des valeurs autorisées, le joueur n'est pas 1 ou 2, ou le carré spécifié n'est pas vide.
int isGameOver () Détermine si la partie est terminée. Renvoie 0 si la partie n'est pas terminée, 1 si X a gagné la partie, 2 si O a gagné la partie, et 3 si la partie est nulle. Les conditions de fin de jeu sont les suivantes:

1: Si une ligne, une colonne ou une diagonale contient tous les X.

2: Si une ligne, une colonne ou une diagonale contient tous les O.

3: S'il n'y a pas de cases vides et que ni X ni O n'ont gagné.

int getNextMove () Retourne un entier représentant le coup suivant pour l'adversaire de l'ordinateur. Cette méthode devrait faire un effort rudimentaire pour sélectionner un bon coup, selon la stratégie suivante:

* Si le centre (carré B2) est vide, jouez le carré central.

* Si le centre n'est pas vide mais que l'un des quatre coins (carrés A1, A3, C1 ou C3) est vide, jouez un des coins (peu importe lequel).

* Si le centre n'est pas vide et qu'aucun coin n'est vide, lisez l'un des bords (carrés A2, B1, B3 ou C2).

String toString () Renvoie une chaîne représentant l'état actuel du tableau. La chaîne inclut des caractères de nouvelle ligne pour afficher les lignes ainsi que des lignes de séparation sur des lignes de console séparées, comme dans cet exemple:

O | | O

- | - | -

| X |

- | - | -

| X |

Comme défi supplémentaire, pour cette version du défi TicTacToeBoard, le joueur informatique devrait utiliser une stratégie plus intelligente contre l'adversaire humain. Déterminez le jeu de l'ordinateur comme suit:

  1. S'il est possible que l'ordinateur gagne lors de son prochain jeu, l'ordinateur doit jouer dans le carré gagnant.

  2. S'il est possible pour l'adversaire humain de gagner lors de son prochain jeu, l'ordinateur devrait jouer dans la case gagnante de l'adversaire humain pour bloquer la victoire.

  3. Si le carré central est disponible, l'ordinateur doit prendre le carré central.

  4. Si un coin est disponible, l'ordinateur doit jouer dans l'un des coins disponibles.

  5. L'ordinateur doit jouer dans un carré de bord disponible.

Notez que pour implémenter cette stratégie, vous devez développer une routine qui peut déterminer si un joueur peut gagner lors de son prochain mouvement. Pour ce faire, vous devrez regarder chacun des huit vecteurs de trois rangs pour déterminer si le vecteur contient un carré vide et si chacun des deux autres carrés contient des marques pour le même adversaire (que est, deux X ou deux O).

Vous pouvez le faire en utilisant 0 pour représenter un carré vide, 1 pour représenter un X et 2 pour représenter un O. Mais cela nécessiterait une logique assez compliquée - quelque chose comme ça serait nécessaire, en supposant que s1, s2, et s3 sont des entiers contenant le contenu des trois carrés de l'un des huit vecteurs trois-de-ligne:

if (s1 == 0 & s2 == 1 & s3 == 1) // X peut gagnez en jouant en s1 si (s2 == 0 & s1 == 1 & s3 == 1) // X peut gagner en jouant en s2 si (s3 == 0 & s1 == 1 & s2 == 1) // X peut gagner en jouant dans s3

Voici donc un conseil: Au lieu d'utiliser 0, 1 et 2 pour représenter un carré vide, un X et un O, utilisez plutôt les nombres premiers 2, 3 et 5.Ensuite, pour déterminer si un joueur peut gagner sur un vecteur donné, il suffit de multiplier les trois valeurs pour ce vecteur. Si le résultat est 18, X peut gagner (233 = 18). Si le résultat est 50, O peut gagner (255 = 50).

Notez également que bien que cette stratégie soit une amélioration par rapport à la stratégie utilisée pour les versions précédentes du programme, elle n'est toujours pas une stratégie parfaite: vous pouvez toujours battre l'ordinateur avec la bonne séquence de jeux. Si vous voulez un défi supplémentaire, réfléchissez à la stratégie supplémentaire qui serait nécessaire pour rendre le jeu impossible à gagner, puis élaborez un moyen d'implémenter la nouvelle stratégie.

Vous pouvez trouver la solution à ce problème dans l'onglet Téléchargements de la page du produit Java Tout-en-un pour les nuls, 4e édition.

Bonne chance!

Défi de programmation java: Ajout de tableaux au programme Simple Tic-Tac-Toe

Le choix des éditeurs

Comment envoyer une vidéo et des photos avec Flip Video - Dummies

Comment envoyer une vidéo et des photos avec Flip Video - Dummies

Après avoir pris photos et vidéos d'événements dans votre vie avec votre caméra Flip Video, vous pouvez les envoyer par e-mail à vos amis et aux membres de votre famille. Le partage de films et d'images que vous capturez et créez en envoyant un message e-mail vous permet de toucher et de toucher quelqu'un avec vos créations, même si vous êtes à proximité ...

Comment enregistrer le son séparément pour votre film numérique - Les mannequins

Comment enregistrer le son séparément pour votre film numérique - Les mannequins

Ont parfois besoin d'un réalisateur enregistrer le son en utilisant un appareil séparé de l'appareil photo, enregistrer le son séparément, puis synchroniser le son sur la vidéo plus tard, lors de l'édition. Habituellement, la raison en est d'augmenter la qualité du son enregistré car de nombreuses caméras n'enregistrent pas le son aussi bien que ...

Comment enregistrer une vidéo avec un caméscope Flip - Les nuls

Comment enregistrer une vidéo avec un caméscope Flip - Les nuls

Enregistrant des vidéos avec votre caméra Flip est comme facile comme 1-2-3 (et 4). Avant d'enregistrer une vidéo, vérifiez les indicateurs d'état de votre Flip pour vous assurer que votre caméra est complètement chargée et qu'elle a suffisamment de temps d'enregistrement pour capturer la vidéo que vous voulez filmer. Pour vérifier le niveau de charge de la batterie de votre Flip (ou ...

Le choix des éditeurs

Mot Raccourcis des symboles 2016 - des mannequins

Mot Raccourcis des symboles 2016 - des mannequins

Dans Word 2016 vous pouvez insérer des symboles communs en utilisant ces raccourcis clavier. Utilisez ces raccourcis clavier au lieu de la commande Insérer → Symbole pour insérer des symboles typographiques communs. Symbole Raccourci Tableau de bord Alt + Ctrl + signe moins En tableau Ctrl + signe moins Copyright Alt + Ctrl + C Marque déposée Alt + Ctrl + R Marque Alt + Ctrl + T Ellipsis Alt + Ctrl + période

Mot Raccourcis des symboles 2016 - mannequins

Mot Raccourcis des symboles 2016 - mannequins

En fonction de la manière dont vous choisissez d'utiliser Word 2016, vous risquez de devoir faire face pour un symbole spécial. Avec ces raccourcis clavier, vous pouvez insérer des symboles communs dans Word 2016. Utilisez ces raccourcis clavier au lieu de la commande Insérer → Symbole pour insérer des symboles typographiques communs. Symbole Raccourci Tableau de bord Alt + Ctrl + signe moins En tiret ...

Mot Trucs et astuces pour les tables 2013 - mannequins

Mot Trucs et astuces pour les tables 2013 - mannequins

Dans Word 2013, le texte se déverse dans un tableau sur une cellule base de la cellule. Vous pouvez taper un mot, une phrase ou même un paragraphe. Tout ce texte reste dans la cellule, bien que la cellule change de taille pour accueillir de plus grandes quantités de texte. Vous pouvez mettre en forme la cellule d'une table comme n'importe quel paragraphe de Word, en ajoutant même des marges ...

Le choix des éditeurs

Sexe For Dummies Cheat Sheet - les nuls

Sexe For Dummies Cheat Sheet - les nuls

Que vous vous considériez comme un Don Juan, une Lady Chatterly, ou un novice sexuel , tout le monde peut tirer le meilleur parti du sexe avec un peu plus de connaissances. Vous devriez savoir que les préliminaires sont quelque chose que vous devriez prendre en considération avec chaque interaction que vous et votre partenaire avez, ainsi que la façon de garder les choses ...

Mots et significations liés à la ménopause - mannequins

Mots et significations liés à la ménopause - mannequins

Bien que ce soit loin d'être une liste complète des termes que vous pourriez entendre être utilisé lorsque la ménopause est discutée, les cinq termes essentiels suivants devraient vous aider à comprendre les bases. HRT (hormonothérapie substitutive): Un traitement pour compléter les hormones que vous perdez pendant la ménopause - généralement une combinaison d'œstrogènes, ...

Symptômes qui indiquent que la ménopause est proche - mannequins

Symptômes qui indiquent que la ménopause est proche - mannequins

La plupart des femmes commencent à éprouver des symptômes de ménopause déséquilibrés, alors qu'ils ont encore des règles. Si vous ressentez un ou plusieurs des symptômes suivants, consultez votre médecin - vous pouvez être en train d'aborder le changement. Peau sèche ou cheveux Pensée floue (difficulté à se concentrer) Flutters du cœur (battements de cœur rapides) ...