Buenas,
Escribo para pedir ayuda con dos cosas, la primera es como hacer para mostrar por pantalla "-" el guion, tantas veces como quiera.
Y la segunda es, leyendo un array con numeros, como hacer para que cuando el numero leido sea 0, muestre por pantalla todo el array y los 0, no muestre nada.
Si el array es:
int tam[10]={1,2,0,4,5,6,0,8,9,10}
Por pantalla aparezca:
1 2 4 5 6 8 9 10
----------------------
Muchas gracias de antemano
En primer lugar aqui no le hacemos los deberes a nadie, solo respondemos dudas.
En segundo lugar:
-Para mostrar el guion una determinada cantidad de veces, puedes crear un array con capacidad para guardar la cantidad de guiones que sea y llenarlo con guiones, y despues recorrerlo imprimiendo cada elemento del array, o puedes crear un array con un elemento mas y ponerle al final el caracter nulo e imprimir directamente el array como si de un string se tratase. De hecho, puedes incluso imprimir un guion la cantidad de veces que necesites.
-Para el otro ejercicio, vas imprimiendo los numeros de uno en uno y si el numero que vas a imprimir es cero imprimes espacio de lo contrario imprimes el numero.
No creo que sean los deberes, mi duda viene cuando, en el caso de los numeros, al compilar me dice que no puedo hacer que cuando lo que lee es un 0, muestre por pantalla un espacio blanco. El codigo es asi:
void mostrar(){
int i, material;
for (i = 0; material = tam[i]; i++){
if (material == 0){
material = " ";
}
cout <<"|" <<material <<"|";
}
cout <<endl;
}
Tal vez quisieras poner:
void mostrar(){
int i, material;
for (i = 0; i<10; i++){ // Condición para romper el bucle: que i no sea menor que 10
material = tam[i]; // Aquí asignas la variable
if (material == 0){
material = " ";
}
cout <<"|" <<material <<"|";
}
cout <<endl;
}
Me sigue dando error de conversion
Oh, el: material = " ";
No puedes asignar una cadena como esa (char*) a un int. Además, un cout d eun int siempre va a escribir un número; no hay ningún número "vacío".
Tendrás que poner 2 cout, uno en el if y otro en el else, por ejemplo.
Y como detalle, cuando tengas dudas así, pon por aquí el error y su línea. El error tal cual te lo pone el compilador.
Osea que seria algo asi:
if (material == 0){
cout <<"| |";
}
else{
cout <<"|" <<material <<"|":
}
El resultado es el que buscas imagino, así que sí.
Muchas gracias, una ultima cosa, porque si leo de un fichero una serie de numeros, lo guardo en un array para el cual uso un typedef y luego lo muestro. Al querer escribir en un nuevo fichero de txto los numeros del array no se escriben y aun asi el compilador me deja compilar, el codigo de escritura es el siguiente:
void pedirSalida(string& msg) {
cout << "Introduzca el nombre del fichero de escritura: ";
cin >> msg;
}
void escribirSalida(string msg, tFilas fila) {
ofstream fichs;
fichs.open(msg);
for (int i = 0; i < 20; i++) {
fichs << fila[i] << endl;
}
fichs.close();
}
Después del "fichs.open(msg);", prueba a poner:
if(!fichs.is_open()){
cout << "Error" << endl;
}
¿El fichero se crea? ¿Tiene algún contenido?
Si, el archivo se crea pero en vez de los numeros que deberia tener en el array aparece -858993460
Pienso que es porqué te graba el número en formato binario y claro, al ser una maquina little endian empieza con el byte de menos peso y termina con el byte de más peso. Después cuándo lees el texto con un editor de texto ves el número fruto de como se ha guardado.
Pero ya te digo que lo pienso. Soy de C, no de C++ así que no puedo hacer la prueba hora mismo. Seguro que hay alguna forma de pasar el número a cadena antes de dárselo a fichs. Es la idea que se me ocurre.
La clase ofstream escribe la representación, no el binario.
Haz una cosa. Pon al lado de la línea, esta otra:
fichs << fila[i] << endl;
cout << fila[i] << endl;
Y a ver qué muestra por pantalla. es posible que el error venga de antes.
Muchas gracias a los dos, ya lo consegui solucionar, solo me faltaba declarar en el main el tFilas fila, ese era el problema, y luego que en el ofstream tenia que pasarlo como const tFilas fila para que no se modificase