habra alguna alma caritativa que me resuelva la siguiente duda?
Lo que quiero hacer es grabar un árbol binario en un archivo, el árbol lo tengo listo, pero la parte de guardarlo en un archivo no tengo ni idea por donde comenzar.
asi va mi arbol
Código C:
Ver original
typedef struct nodoarbol { //ESTRUCTURA DEL ARBOL char placa[10]; int cedula; char nombre[20]; char marca[15]; char modelo[15]; int anio; char color[10]; char serial_motor[20]; char email[25]; struct nodoarbol *izq; struct nodoarbol *der; }NODO;
asi va el main
Código C:
Ver original
int main() { NODO *raiz=NULL; FILE *fichero; { } int ci=0,anio; char placa[10],placa2[10],placa3[10]; char nombre[20],marca[15],modelo[15]; char color[10],ser_motor[20],email[25]; int numero,opc,elim; while(opc!=6) { switch(opc) { case 1: insertanodonuevo(raiz,placa,ci,nombre,marca,modelo,anio,color,ser_motor,email); ///inserto datos al arbol. break; inorden(raiz); break; case 3: verArbol(raiz); break; //gets(placa); break; //gets(placa); eliminarElemArbol(raiz,placa3); break; } } }
mi pregunta es como hago para guardar los datos en el archivo? se que tengo que abrir el archivo con fopen en modo añadir y luego utilizar la función fwrite(&r,sizeof(NODO),1,f); , pero lo que no entiendo es en donde aplicarlo?
por ejemplo si lo hago de esta manera, seria lo correcto?
Código C:
Ver original
void insertanodonuevo(NODO *&rarbol,char nuevo[],int ced,char nomb[],char marc[],char mod[],int anio,char color[],char ser_motor[],char email[]) { NODO r; FILE *f; if(rarbol==NULL) { if(rarbol!=NULL) { rarbol->cedula=ced; rarbol->anio=anio; rarbol->izq=NULL; rarbol->der=NULL; } else { } } else insertanodonuevo(rarbol->izq,nuevo,ced,nomb,marc,mod,anio,color,ser_motor,email); else insertanodonuevo(rarbol->der,nuevo,ced,nomb,marc,mod,anio,color,ser_motor,email); else }
o lo tengo que hacer en el main?
de igual manera para leer el archivo... así lo hago pero evidentemente no funciona
///funcion para mostrar los datos del arbol en orden.
Código C:
Ver original
void inorden(NODO *rarbol) { NODO r; FILE *f; { if(rarbol) { inorden(rarbol->izq); inorden(rarbol->der); } } }