Exercice02_JeuPenduRetourTélécharger Cette exrcice consiste à réviser les chaines de caractères en développant le jeu du pendu : découvrir une mot cachée en proposant lettre par lettre. EnonceExercice02.pdf Exercice02.java //Cette exrcice consiste à réviser les chaines de caractères en développant le jeu du pendu : découvrir une mot cachée en proposant lettre par lettre. import java.util.*; /* Enoncé : -------- On se propose d'écrire en Java le jeu du pendu définit de la manière suivante : - le programme lit un fichier texte contenant les mots à découvrir. Chaque ligne du fichier contient un mot - le programme choisit un mot au "hasard" (utilisez System.currentTimeMiliss()) et le propose o int n = (int)( System.currentTimeMiliss() ); - le joueur gagne s'il trouve en 7 coups ou moins - le jeu affiche les lettres jouées - le joueur ne peut pas choisir une lettre déjà jouée - le jeu affiche le mot à trouver avec une étoile pour les lettres non encore trouvées */ public class Exercice02 { public static void main(String args[]) { // Lecture du fichier contenant les mots a decouvrir // String[] mots = Terminal.lireFichierTexte("../Pendu.txt"); // Pour vérifier le fichier /* for(int i=0;i<mots.length;i++) Terminal.ecrireStringln(i + ": ["+mots[i]+"]"); Terminal.ecrireStringln("---------------"); */ // On prend un mot aleatoirement : modulo du temps courant // int aleat = Math.abs( (int)(System.currentTimeMillis()) ); int numero = aleat%mots.length; String mot = mots[numero]; // Le mot a trouver est transformer en tableau char[] motATrouve = mot.toCharArray(); // Le mot cache de la longueur du mot a trouver contient au départ que des "-" char[] motCache = new char[motATrouve.length]; for(int i=0;i<motCache.length;i++) motCache[i] = '-'; // Nombre d'erreur du joueur. A plus de 7 erreurs il a perdu. int nbErreur = 0; int nbMaxErreur = 7; // Les lettrejouees par le joueur et son nombre de coup joues char[] lettreJouees = new char[26]; int nbCoupJoues = 0; // Boucle de jeu // boolean fini = false; while(!fini) { // Si le joueur a perdu if (nbErreur>nbMaxErreur) { Terminal.ecrireString("Perdu! Le mot est: "+mot); fini = true; } else { Terminal.ecrireString("Mot a trouver : "); Terminal.ecrireStringln(new String(motCache)); Terminal.ecrireString("Lettres jouees : "); Terminal.ecrireStringln(new String(lettreJouees)); Terminal.ecrireString("Nb erreurs : "); Terminal.ecrireStringln(""+nbErreur); Terminal.ecrireString("Saisir un car : "); char caracJoue = Terminal.lireChar(); // Si le caractere joue a deja ete jouee if (caracDansTab(caracJoue,lettreJouees)) System.out.println("Caractere deja joue"); else { // Si le caractere joue fait parti du mot a trouve // alors on decouvre les lettres // sinon le joueur a fait une erreur // if (caracDansTab(caracJoue,motATrouve)) { if (majMotCache(caracJoue,motCache,motATrouve)) { fini=true; Terminal.ecrireStringln("Bravo!!"); } } else { nbErreur++; } // On stocke le caractère joué lettreJouees[nbCoupJoues]=caracJoue; nbCoupJoues++; } } } } // Recherche si le caractere est dans un tableau de caractère // static boolean caracDansTab(char c,char[] tab) { for(char e:tab) { if (c==e) return true; } return false; } // Remplace les '-' par le caractère joue si il existe. // Retourne true si toutes les lettres ont été trouvées // static boolean majMotCache(char c,char[] motCache,char[] motATrouve) { int nbc=0; for(int i=0;i<motCache.length;i++) { if(motATrouve[i]==c) motCache[i]=c; if(motCache[i]=='-') nbc++; } if (nbc==0) return(true); else return false; } } Pendu.txt voiture maisons ordinateur clavier souris ecran whisky campagne telephone vase table chaise grenouille aspirateur photographie verre bouteille stylo agenda programme java biscuit fourchette lunette cahier fenetre parking Terminal.java import java.io.*; import java.util.*; /** La classe Terminal permet de réaliser ses premiers programmes Java en permettant d'afficher dans la console d'exécution des données de type différents, et en permettant de saisir au clavier des données de type différents.<BR> Elle permet aussi de lire et écrire un fichier texte Cette classe contient que des méthodes statiques. */ public class Terminal{ // Le buffer standard de lecture = le clavier private static BufferedReader in = new BufferedReader(new InputStreamReader(System.in)); /** Cette méthode lit un fichier texte et retourne le contenu du fichier sous la forme d'un tableau de String dont chaque element est une ligne du fichier. @param nomFichier le nom du fichier qui doit être dans le répertoire courant. @return String[] le contenu du fichier. @exception TerminalException (de type RuntimeException) si erreur d'écriture<BR> Rappel : Une exception de type RuntimeException n'a pas l'obligation d'être capturée. */ public static String[] lireFichierTexte(String nomFichier) { try{ File fichier = new File(nomFichier); FileInputStream fis = new FileInputStream(new File(nomFichier)); byte[] buffer = new byte[(int)fichier.length()]; fis.read(buffer); fis.close(); String str = new String(buffer); // On enleve le caractère '\r' code 13 qui est ajouté en Windows // Les fins de ligne dans un fichier texte créé sous Windows // se termine par \r\n. // Il faut enlever le \r car il a des effets perturbant sur // la méthode System.out.print et est pris comme un caractère de plus // qu'il faut éliminer // String texte = str.replaceAll(""+(char)(13),""); // Les lignes du fichier sont mises dans un tableau // String[] mots = texte.split("\n"); return(mots); } catch(Exception ex) { exceptionHandler(ex); } return null; } /** Cette méthode permet de créer un fichier texte à partir du contenu d'un StringBuffer. @param nomFichier Le nom du fichier qui est créé dans le répertoire courant @param strbuf Le StringBuffer contenant le texte à écrire. @exception TerminalException (de type RuntimeException) si erreur d'écriture */ public static void ecrireFichier(String nomFichier, StringBuffer strbuf) { try{ File fichier = new File(nomFichier); FileOutputStream fos = new FileOutputStream(new File(nomFichier)); byte[] buffer = strbuf.toString().getBytes(); fos.write(buffer); fos.close(); } catch(Exception ex) { exceptionHandler(ex); } } /** Cette méthode lit une chaîne de caractère @return String la chaîne saisie dans la console d'exécution @exception TerminalException (de type RuntimeException) si erreur de lecture */ public static String lireString() // Lire un String { String tmp=""; char C='\0'; try { tmp = in.readLine(); } catch (IOException e) { exceptionHandler(e); } return tmp; } /** Cette méthode lit un entier @return int L'entier saisi dans la console d'exécution @exception TerminalException (de type RuntimeException) si la saisie n'est pas un entier ou erreur de lecture */ public static int lireInt() // Lire un entier { int x=0; try { x=Integer.parseInt(lireString()); } catch (NumberFormatException e) { exceptionHandler(e); } return x ; } /** Cette méthode lit un boolean (false ou true) @return boolean Le boolean saisi dans la console d'exécution @exception TerminalException (de type RuntimeException) si erreur de lecture. <BR> Tout autre valeur que TRUE, FALSE, true ou false, retourne la valeur false */ public static boolean lireBoolean() // Lire un entier { boolean b = true; try { b = Boolean.valueOf(lireString()).booleanValue(); } catch (NumberFormatException e) { exceptionHandler(e); } return b; } /** Cette méthode lit un double @return double Le double saisi dans la console d'exécution @exception TerminalException (de type RuntimeException) si la valeur saisie n'est pas un double ou ereur de lecture. */ public static double lireDouble() // Lire un double { double x=0.0; try { x=Double.valueOf(lireString()).doubleValue(); } catch (NumberFormatException e) { exceptionHandler(e); } return x ; } /** Cette méthode lit un caractère. @exception TerminalException (de type RuntimeException) si erreur de lecture.<BR> Si on saisit plus d'1 caractère alors le caractère retourné est le premier. */ public static char lireChar() // Lire un caractere { String tmp=lireString(); if (tmp.length()==0) return '\n'; else { return tmp.charAt(0); } } /** Cette méthode écrit une chaine et ne revient pas à la ligne. @param s la chaine à écrire */ public static void ecrireString(String s){ // Afficher un String System.out.print(s); } /** Cette méthode écrit une chaine et revient à la ligne. @param s la chaine à écrire */ public static void ecrireStringln(String s) // Afficher un String { ecrireString(s); sautDeLigne(); } /** Cette méthode écrit un entier et ne revient pas à la ligne. @param i l'entier à écrire */ public static void ecrireInt(int i) // Afficher un entier { ecrireString(""+i); } /** Cette méthode écrit un entier et revient à la ligne. @param i l'entier à écrire */ public static void ecrireIntln(int i) // Afficher un entier { ecrireString(""+i); sautDeLigne(); } /** Cette méthode écrit un booléan et ne revient pas à la ligne. @param b le booléen à écrire */ public static void ecrireBoolean(boolean b){ ecrireString(""+b); } /** Cette méthode écrit un booléan et revient à la line. @param b le booléen à écrire */ public static void ecrireBooleanln(boolean b){ ecrireString(""+b); sautDeLigne(); } /** Cette méthode écrit un double et ne revient pas à la ligne. @param d le double à écrire */ public static void ecrireDouble(double d) // Afficher un double { ecrireString(""+d); } /** Cette méthode écrit un double et revient à la ligne. @param d le double à écrire */ public static void ecrireDoubleln(double d) // Afficher un double { ecrireDouble(d); sautDeLigne(); } /** Cette méthode écrit un caractère et ne revient pas à la ligne. @param c le caractère à écrire */ public static void ecrireChar(char c) // Afficher un caractere { ecrireString(""+c); } /** Cette méthode écrit un caractère et revient à la ligne. @param c le caractère à écrire */ public static void ecrireCharln(char c) // Afficher un caractere { ecrireChar(c); sautDeLigne(); } /** Cette méthode revient à la ligne. */ public static void sautDeLigne(){ try{ System.out.println(); }catch(Exception ex){ exceptionHandler(ex); } } /** Cette méthode retourne l'exception TerminalException */ protected static void exceptionHandler(Exception ex){ TerminalException err = new TerminalException(ex); throw err; } /** Cette méthode écrit une exception avec la pile dans la console @param ex l'exception à écrire */ public static void ecrireException(Throwable ex){ ecrireString(ex.toString()); ex.printStackTrace(System.out); } } /** Classe de définition de l'exception TerminalException qui peut être retournée dans l'usage des méthodes de la classe Terminal. */ class TerminalException extends RuntimeException{ Exception ex; TerminalException(Exception e){ ex = e; } } compil.bat mkdir bin del /f /s /q bin\*.class javac -d bin *.java pause run.bat cd bin java Exercice02 pause