Pregunta

Si tengo dos funciones:

void SortStudents(char *studentList[], size_t studentCount) 
{
    qsort(studentList, sizeof(studentList)/sizeof(studentList[0]), sizeof(studentList[0]), Compare);
}

int Compare(const void *a, const void *b) 
{
    return (strcmp(*(char **)a, *(char **)b));
}

Ese tipo y comparar usando la función qsort, ¿cómo lo uso bsearch encontrar subconjuntos de mi lista. Por ejemplo, si tengo dos listas:

  • (Lista A) Bob, Jimmy Lee, James, Anne
  • (Lista B) Jen, Jon Lee, James, Steph

¿Cómo se busca en la lista B para encontrar a los elementos de A?

Puede también hacer una búsqueda en la lista B para encontrar aquellos elementos no en A?

Gracias.

¿Fue útil?

Solución

Para hacer una búsqueda, usted tiene que utilizar una lista de un solo elemento como el parámetro clave para 'bsearch ()'.

En el contexto, la búsqueda de la entrada en a_list[n] en b_list:

 void *found = bsearch(&a_list[n], b_list, b_list, b_size, Compare);

Por lo tanto, para encontrar los elementos de la Lista B que se encuentran en la Lista A, que va a hacer:

  • Ordenar la lista B (que no es necesario para ordenar la lista A de esta parte del ejercicio, a menos que quiera)
  • Para cada elemento en la Lista A, buscar el elemento en (la ordenada) Lista B.

Y para encontrar los elementos de B que no están en A, que tendrá que ordenar la lista A, después de todo y luego para cada elemento en la Lista B, ver si el elemento está en la lista A con la búsqueda inversa.


#include <stdio.h>
#include <stdlib.h>
#include <string.h>

static char *a_list[] = { "Bob", "Jimmy", "Lee", "James", "Anne"  };
static char *b_list[] = { "Jen", "Jon",   "Lee", "James", "Steph" };
static size_t a_number = sizeof(a_list)/sizeof(a_list[0]);
static size_t b_number = sizeof(b_list)/sizeof(b_list[0]);

static int Compare(const void *a, const void *b) 
{
    return (strcmp(*(char **)a, *(char **)b));
}

void SortStudents(char *studentList[], size_t studentCount) 
{
    qsort(studentList, studentCount, sizeof(studentList[0]), Compare);
}

static void dump_list(const char *tag, char **list, size_t number)
{
    size_t i;
    printf("%s:\n", tag);
    for (i = 0; i < number; i++)
        printf(" %s%s", list[i], (i == number - 1) ? "" : ",");
    putchar('\n');
}

static char *search_list(char *name, char **list, size_t number)
{
    char **found = bsearch(&name, list, number, sizeof(*list), Compare);
    return((found == 0) ? 0 : *found);
}

static void names_in_list(char **find_list, size_t find_number, char **name_list, size_t name_number)
{
    size_t i;
    for (i = 0; i < find_number; i++)
    {
        char *name = search_list(find_list[i], name_list, name_number);
        if (name != 0)
            printf("Found %s in list at %s\n", find_list[i], name);
    }
}

static void names_not_in_list(char **find_list, size_t find_number, char **name_list, size_t name_number)
{
    size_t i;
    for (i = 0; i < find_number; i++)
    {
        char *name = search_list(find_list[i], name_list, name_number);
        if (name == 0)
            printf("Did not find %s in list\n", find_list[i]);
    }
}

int main(void)
{
    dump_list("Unsorted A list", a_list, a_number);
    dump_list("Unsorted B list", b_list, b_number);
    SortStudents(a_list, a_number);
    SortStudents(b_list, b_number);
    dump_list("Sorted A list", a_list, a_number);
    dump_list("Sorted B list", b_list, b_number);
    dump_list("Searching in B list for people in A list", b_list, b_number);
    names_in_list(a_list, a_number, b_list, b_number);
    dump_list("Searching in A list for people not in B list", a_list, a_number);
    names_not_in_list(b_list, b_number, a_list, a_number);
    return(0);
}

Y la salida fue:

Unsorted A list:
 Bob, Jimmy, Lee, James, Anne
Unsorted B list:
 Jen, Jon, Lee, James, Steph
Sorted A list:
 Anne, Bob, James, Jimmy, Lee
Sorted B list:
 James, Jen, Jon, Lee, Steph
Searching in B list for people in A list:
 James, Jen, Jon, Lee, Steph
Found James in list at James
Found Lee in list at Lee
Searching in A list for people not in B list:
 Anne, Bob, James, Jimmy, Lee
Did not find Jen in list
Did not find Jon in list
Did not find Steph in list
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top