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
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
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
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 if(st(nuevo,rarbol->placa)) insertanodonuevo(rarbol->izq,nuevo,ced,nomb,marc,mod,anio,color,ser_motor,email); else if(st(nuevo,rarbol->placa) 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
void inorden(NODO *rarbol) { NODO r; FILE *f; { if(rarbol) { inorden(rarbol->izq); inorden(rarbol->der); } } }