-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathPalabra.h
111 lines (84 loc) · 3.02 KB
/
Palabra.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
* -------------------------------
* Juego del Ahorcado en C++ -----
* Autor: Rubén Rodríguez --------
* Fecha: 14-4-19 ----------------
* -------------------------------
*/
#ifndef PALABRA_H
#define PALABRA_H
/*
* Fichero de interfaz del módulo palabra
*/
#include <iostream>
#include <iomanip>
#include <cstring>
#include <fstream>
#include <conio.h>
using namespace std;
// Longitud de la palabra mas larga conocida
const int MAX_LETRAS = 33;
struct Palabra {
private:
// Estructura interna del tipo de dato Palabra
char cadena[MAX_LETRAS]; // vector de caracteres que representa las letras de la palabra
bool marcadas[MAX_LETRAS - 7]; // vector que representa las letras descubertas y las que no
int numLetras; // numero de letras de la palabra
public:
/*
* Pre: <<secuencia>> es una secuencia de caracteres que representa una
* palabra de la lengua española y <<nLetras>> es el total de letras
* de la cadena <<secuencia>>
* Post: Ha creado una palabra asignado a <<cadena>> la secuencia de caracteres
* <<secuencia>> y a <<numLetras>> el valor de <<nLetras>>
*/
friend void crearPalabra(char secuencia[], int nLetras, Palabra& p);
/*
* Pre: ---
* Post: Ha copiado en <<palabra>> la secuencia de caracteres
* almacenados en <<cadena>>
*/
friend void obtenerPalabra(char palabra[], Palabra& p);
/*
* Pre: ---
* Post: Ha devuelto el total de letras de la palabra
*/
friend int obtenerLetras(Palabra& p);
/*
* Pre: ---
* Post: Ha devuelto la i-esima letra de la palabra <<p>>
*/
friend char devolverLetra(Palabra& p, const int i);
/*
* Pre: ---
* Post: Ha mostrado por cada letra de la palabra <<p>> un guion
* bajo de acuerdo al siguiente formato
*
* Ejemplo:
* diligentemente: _ _ _ _ _ _ _ _ _ _ _ _ _ _
* ababol: _ _ _ _ _ _
* ganzua: _ _ _ _ _ _
*/
friend void mostrarHuecosPalabra(Palabra& p);
/*
* Pre: <<p>> es una secuencia de caracteres que describe la
* estructura de una palabra
* Post: Ha devuelto <<true>> si y solo si la letra <<l>> esta dentro
* de la palabra <<p>> y ha reemplazada en la posicion correspondiente
* el caracter "_" por el valor de la letra <<l>>
*/
friend void existeLetra(Palabra& p, const char l, int& letrasVoltedas, bool& encontrado, bool& letraYaDicha);
/*
* Pre: <<ficheroPalabrasBinario>> es un fichero binario que almacena una secuencia de
* de palabras, <<numLineas>> es el numero de lineas del fichero
* Post: Ha seleccionado una fila aleatoria del fichero <<ficheroPalabrasBinario>> y ha guardado en
* <<p>> la palabra correspondiente a esa linea
*/
friend void seleccionarPalabra(const char ficheroPalabrasBinario[], const int numLineas, Palabra& p);
/*
* Pre: ---
* Post Ha mostrado por pantalla la palabra oculta
*/
friend void mostrarPalabra(Palabra& p);
};
#endif