es la primera vez que utilizo las funciones qsort y bsearch, y miro y miro el código y no entiendo qué hago mal, así que si alguien lo ve, me haría un gran favor al decírmelo.
El programa se trata de crear una lista que ordene por el primer apellido (cognom1), y, si se da el caso de que hubieran dos iguales, se escribe la información sobre el DNI menor.
aquí lo dejo, y ante todo, ¡muchas gracias por vuestro tiempo!
Código
#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct{ char carrer[16]; char num[5]; char poblacio[16]; char codiPostal[5]; }adreca; typedef struct{ char nom[11]; char cognom1[16]; char cognom2[16]; adreca dir; int dni; char sexe; }persona; int ordenar(const void *,const void *); int main(void){ int n, i; persona *v, *trobat, p, *ap; for(i=0; i<n; i++){ } ap = &p; return 0; } int ordenar(const void *a1, const void *a2){ persona p1, p2; int k; p1 = *(persona *)a1; p2 = *(persona *)a2; if(k!=0) return k; return p1.dni - p2.dni; }