Autor
|
Tema: Duda Memoria Dinamica (Leído 3,212 veces)
|
Pepe2009
Desconectado
Mensajes: 3
|
Buenos dias: Necesito leer un fichero de texto de vuelos y otro de pasajeros guardarlo en memoria en un array de registros, y posteriormente gestionarlo de momento he conseguido leer uno y gestionarlo, pero no se como almacenarlo en memoria dinamica para que vaya leyendo todos. Los problemas principales es que debo leer de un fichero de texto con los campos separados por almohadillas y la otra duda es que debo almacenar todo el texto en memoria sin saber el numero de registros a almacenar. Adjunto programa que ya he hecho por si me podeis echar una mano. #include <stdio.h> typedef struct Reg_Vuelos { char IDVuelo[6]; char Operadora[7]; char Aerolinea[5]; char TipoAvion[4]; char NumPasajV[4]; struct Reg_Vuelos *Siguiente; }Reg_Vuelos; typedef struct Reg_Pasajeros { char NumPasajP[4]; char DNI[9]; char Nombre[30]; char Aerolinea[5]; char TipoAvion[4]; char Fecha; }Reg_Pasajeros; Reg_Vuelos RVuelos; Reg_Pasajeros RPasajeros; int main () { int Var_Aux = 1; // Variable Auxiliar utilizada para recorrer cada uno de los campos del Registro RegVuelos. // Variables utilizadas dentro del bucles que verifica cuantos clientes vuelan el mismo dia. int p; int Coincidencias = 0; int Repeticiones = 0; int k = 0; int Avance; char i = 0; // Variable utilizada para rellenar cada uno de los caracteres de los campos del Registro RegVuelos. char j = 1; // Variable utilizada para rellenar el campo de los vuelos en que no viajan clientes de nuestra operadora. char Cadena_AuxV[40]; // Cadena Auxiliar para recorrer el Archivo Vuelos.txt. char Cadena_AuxP[40]; // Cadena Auxiliar para recorrer el Archivo Pasajeros.txt. // Variables utilizadas para Contabilizar los clientes que vuelan en estas Aerolineas. int Iberia = 0; int Luftansa = 0; int American = 0; int Ryanair = 0; printf ("Ejecutando proceso. \n\n"); printf ("Fichero Informe rellenado. Pulse una tecla \n\n"); // Apertura de los tres ficheros de texto a utilizar, Vuelos y Pasajeros en modo lectura y el fichero de salida, Informe en modo escritura FILE *Vuelo = fopen("Vuelos.txt", "r"); if (Vuelo == NULL) { perror ("Error al abrir fichero.txt"); return -1; } FILE *Pasajero = fopen("Pasajeros.txt", "r"); if (Pasajero==NULL) { perror ("Error al abrir fichero.txt"); return -1; } FILE *Informe = fopen("Informe.txt", "w"); if (Informe==NULL) { perror ("Error al abrir fichero.txt"); return -1; } fprintf (Informe , "Clientes que vuelan mas de dos veces el mismo dia: \n"); // Comienza el bucle principal do { Var_Aux = 1; i = 0; // Leemos una linea completa del fichero Vuelos.txt y la vamos guardando en la estructura registro do { Cadena_AuxV [1] = fgetc (Vuelo ); if (Var_Aux == 1) { i++; RVuelos.IDVuelo[i]= Cadena_AuxV[1]; if (Cadena_AuxV[1] == '#') { Var_Aux++; i = 0; Cadena_AuxV [1] = fgetc (Vuelo ); } } if (Var_Aux == 2) { i++; RVuelos.Operadora[i]= Cadena_AuxV[1]; if (Cadena_AuxV[1] == '#') { Var_Aux++; i = 0; Cadena_AuxV [1] = fgetc (Vuelo ); } } if (Var_Aux == 3) { i++; RVuelos.Aerolinea[i]= Cadena_AuxV[1]; if (Cadena_AuxV[1] == '#') { Var_Aux++; i = 0; Cadena_AuxV [1] = fgetc (Vuelo ); } } if (Var_Aux == 4) { i++; RVuelos.TipoAvion[i]= Cadena_AuxV[1]; if (Cadena_AuxV[1] == '#') { Var_Aux++; i = 0; Cadena_AuxV [1] = fgetc (Vuelo ); } } if (Var_Aux == 5) { i++; RVuelos.NumPasajV[i] = Cadena_AuxV[1]; } } while (Cadena_AuxV[1] != '\n'); // Comprobamos si el cliente es de Nuestra Operadora que Aerolinea ha preferido. if (RVuelos.Operadora[1] == 'N') { switch (RVuelos.Aerolinea[1]) { case 'I': Iberia ++; break; case 'A': American ++; break; case 'R': Ryanair ++; break; case 'L': Luftansa ++; break; } } else { fprintf (Informe , "\nVuelo en el que no viajan clientes de nuestra operadora: "); for (j=1; j<7; j++) { fprintf (Informe , "%c", RVuelos. IDVuelo[j ]); } } // Este bucle lee el fichero Pasajeros, para comprobar si un cliente vuela varias veces en el mismo dia. do { k = 1; do { Avance = 0; Cadena_AuxP [1] = fgetc (Pasajero ); RPasajeros.NumPasajP[k]= Cadena_AuxP[1]; if (RPasajeros.NumPasajP[k] == RVuelos.NumPasajV[k]) { Coincidencias ++; if (Coincidencias == 4) { Repeticiones ++; Coincidencias = 0; if (Repeticiones == 2) { while (Cadena_AuxP[1] != '#') { Cadena_AuxP [1] = fgetc (Pasajero ); } for (p = 1; p<10; p++) { Cadena_AuxP [1] = fgetc (Pasajero ); RPasajeros.DNI[p]= Cadena_AuxP[1]; fprintf (Informe ,"%c", RPasajeros. DNI[p ]); } Cadena_AuxP [1] = fgetc (Pasajero ); Repeticiones = 0; for (p = 1; p<14; p++) { Cadena_AuxP [1] = fgetc (Pasajero ); RPasajeros.Nombre[p]= Cadena_AuxP[1]; fprintf (Informe , "%c", RPasajeros. Nombre[p ]); } Avance = 1; for (p = 1; p<13; p++){ Cadena_AuxP [1] = fgetc (Pasajero ); } } } } else { Coincidencias = 0; } k ++; } while (k < 5); if (Avance != 1) {for (p = 1; p<37; p++){ Cadena_AuxP [1] = fgetc (Pasajero );}} } while ((Cadena_AuxP [1]=fgetc(Pasajero )) != EOF ); } while ((Cadena_AuxV [1]=fgetc(Vuelo )) != EOF ); return 0; }
|
|
« Última modificación: 13 Agosto 2013, 17:06 pm por Pepe2009 »
|
En línea
|
|
|
|
do-while
Desconectado
Mensajes: 1.276
¿Habra que sacarla de paseo?
|
Buf... Vaya montón de código. Te recomiendo que edites el post y pongas el código dentro de las etiquetas correspondientes GsSHi (en el modo de edición la pestaña de arriba a la derecha). Si quieres ir añadiendo registros a un vector de forma dinámica puedes utilizar la función realloc, y para saber cuantos elementos tienes almacenados solo tendrás que incrementar un contador cada vez que añadas un elemento al vector: int añadir_entero(int **vector, int valor, int *nelementos) { int *aux; if(!(aux = realloc(*vector ,((*nelementos ) + 1) * sizeof(int)))) return 0; *vector = aux; (*vector)[*nelementos] = valor; (*nelementos)++; return 1; }
¡Saludos!
|
|
« Última modificación: 13 Agosto 2013, 14:18 pm por do-while »
|
En línea
|
- Doctor, confundo los números y los colores. - Vaya marrón. - ¿Marrón? ¡Por el culo te la hinco!
|
|
|
amchacon
Desconectado
Mensajes: 1.211
|
Un realloc es una operación muy costosa, yo lo haría de forma amortiguada. Es decir, de 10 en 10: int añadir_entero(int **vector, int valor, int *nelementos) { static int Actual = 0; if (Actual == 10) { int *aux; if(!(aux = realloc(*vector ,((*nelementos ) + 10) * sizeof(int)))) return 0; *vector = aux; (*nelementos) += 10; Actual = 0; } (*vector)[*nelementos-(10-Actual)] = valor; Actual++; return 1; }
|
|
« Última modificación: 13 Agosto 2013, 14:27 pm por amchacon »
|
En línea
|
|
|
|
do-while
Desconectado
Mensajes: 1.276
¿Habra que sacarla de paseo?
|
Hum... No es por meter el dedo en el ojo , pero... y si utilizas la funcion con distintos vectores,desde distintas partes del codigo... la función puede fallar: 9 llamadas con un vector, 1 llamada con otro, y si repetimos la secuencia, nos salimos de la memoria asignada con el primer vector... Y la primera llamada debería de reservar memoria, seria Actual = 10, ¿No? Lo siento, tengo el día vacilón. Demasiada calor... ¡Saludos!
|
|
|
En línea
|
- Doctor, confundo los números y los colores. - Vaya marrón. - ¿Marrón? ¡Por el culo te la hinco!
|
|
|
Pepe2009
Desconectado
Mensajes: 3
|
El enunciado es el siguiente,
Para mejorar la atención al público de nuestra operadora de viajes de negocios debemos desarrollar una aplicación que transforme y estudie el fichero que, sobre el tráfico aéreo europeo, publica Eurocontrol. El fichero que recibimos de Eurocontrol es un fichero diario de texto con el siguiente formato: Nº vuelos IDVuelo#Operadora#Aerolínea#TipoAvión#NºPasajeros IDVuelo#Operadora#Aerolínea#TipoAvión#NºPasajeros ……… Para la gestión de la web de nuestra operadora disponemos de otro fichero en modo texto con el siguiente formato: Nº pasajeros DNI#Nombre#Aerolínea#TipoAvión#Fecha DNI#Nombre#Aerolínea#TipoAvión#Fecha ……… La práctica consistirá en implementar una aplicación que recibirá el nombre de los dos ficheros como argumentos y transformará los archivos de datos en una estructura de datos en memoria de la forma siguiente:
Una vez creada la estructura de la figura anterior, el programa emitirá un informe que almacenará en un fichero de texto. El informe constará de un listado de los vuelos en los que no viajan clientes de nuestra operadora, el nombre de la aerolínea en la que más vuelan nuestros clientes y el nombre y el DNI de los clientes que aparezcan más de una vez en la estructura, es decir, de aquellos clientes que ese día viajen en avión más de una vez. El acceso a ficheros y el uso de memoria deberán ser lo más eficientes posibles. El programa deberá estar correctamente estructurado en distintos ficheros con sus correspondientes cabeceras.
|
|
|
En línea
|
|
|
|
do-while
Desconectado
Mensajes: 1.276
¿Habra que sacarla de paseo?
|
No te vamos a hacer el trabajo. Has empezado bien, planteando una duda en concreto y te hemos dado dos soluciones alternativas, pero no pretendas que se te haga el trabajo. ¡Saludos!
|
|
|
En línea
|
- Doctor, confundo los números y los colores. - Vaya marrón. - ¿Marrón? ¡Por el culo te la hinco!
|
|
|
Pepe2009
Desconectado
Mensajes: 3
|
Por supuesto, no es lo que pretendo, dime como aprendo yo si el trabajo lo haces tu. Si he puesto las aclaraciones es por que he entendido que me lo decias asi, pero no te preocupes, dentro de un rato lo borro y continuo por mi cuenta. Gracias por los consejos.
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
[DUDA] Memoria Dinámica en C++
Programación C/C++
|
Zodiak98
|
3
|
2,626
|
5 Junio 2013, 18:48 pm
por Zodiak98
|
|
|
Duda sobre memoria dinamica C++
Programación C/C++
|
erest0r
|
6
|
3,944
|
11 Septiembre 2013, 09:34 am
por erest0r
|
|
|
Duda con memoria dinámica y arrays
Programación C/C++
|
Bob1098
|
6
|
2,534
|
7 Septiembre 2015, 18:47 pm
por Bob1098
|
|
|
Duda con memoria dinamica
Programación C/C++
|
Ja_90
|
2
|
1,798
|
20 Octubre 2015, 19:17 pm
por Ja_90
|
|
|
[C] (Consulta) Duda cuando un programa en C termina y memoria dinámica
Programación C/C++
|
class_OpenGL
|
4
|
2,520
|
29 Mayo 2016, 21:19 pm
por class_OpenGL
|
|