Переместите указатели, чтобы печатать в другом порядке

Я должен завершить эту программу.

У меня есть такой файл

Name iD Num_of_elements elem(1) elem(2), ... , elem(n)
james 1 3 AAA BBB CCC
arthur 2 2 EEE FFF
james 1 1 KKK
irine 3 4 EEE FFF DDD AAA
james 1 1 XXX

Мне нужно создать список, загрузить файл в список и распечатать его в следующем порядке:

james 1 3 AAA BBB CCC
james 1 1 XXX
james 1 1 KKK
arthur 2 2 EEE FFF
irine 3 4 EEE FFF DDD AAA

(необходимо печатать людей с тем же iD прежде, чем другие).

Я создал часть программы в ANSI C, но я не могу завершить "финальную функцию" как запрос.

void printListOrderedByiD (struct list * top) {}

Это мой код

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define len 35

struct elements
{
    char name[len];
};

struct list
{
    char name[len];
    int id;
    int numOfElements;
    struct elements *pElements; /* pointer to the struct elements */
    struct list *next;
};


FILE *openFile(FILE *fp)
{
    fp=fopen("file.txt", "r");
        if (fp==NULL)
            {
                perror("");
                exit(1);
            }
    return (fp);
}


struct list *newNode(FILE *fp)
{
    int i=0;
    struct list *temp=(struct list *)malloc(sizeof(struct list));

    fscanf(fp, "%s\t%d\t%d\t", temp->name, &temp->id, &temp->numOfElements);

    temp->pElements=(struct elements *)malloc(temp->numOfElements*sizeof(struct elements));

        for (i=0; i<temp->numOfElements; i++)
        {
            fscanf(fp, "%s\t", temp->pElements[i].name);
        }

        temp->next=NULL;

    return temp;
}

struct list *insertAsLast(struct list *top, FILE *fp) /* this function will insert every node at the end of the list */
{
    if (top==NULL)
    {
        top=newNode(fp);
    }
    else
    {
        top->next=insertAsLast(top->next, fp);
    }

return top;
}

void printList(struct list *top) /* this procedure will stamp the list as loades from the file */
{
    int i=0;

    if (top==NULL)
    {
        printf("//\n");
    }
    else
    {
        printf("%s %d %d ", top->name, top->id, top->numOfElements);

            for (i=0; i<top->numOfElements; i++)
            {
                printf("%s ", top->pElements[i].name);
            }
            printf("\n");

        printList(top->next);
    }
}


int main()
{
    struct list *top=NULL;
    char firstLine[200];
    FILE *fp=NULL;
    fp=openFile(fp);

        fgets(firstLine, 200, fp); /* in order to jump the 1st line */

            while (!feof(fp))
            {
                top=insertAsLast(top, fp);
            }
    fclose (fp);

    printList(top);

    return 0;
}

кто-нибудь может мне помочь?

1 ответ

Сортировка по идентификатору хранится в массиве временно.

static int cmp(const void *a, const void *b){
    int x = (*(struct list**)a)->id;
    int y = (*(struct list**)b)->id;
    return x < y ? -1 : x > y;
}
void printListOrderdByID(struct list *top){
    struct list **table, *p;
    size_t size=16, n=0, i;
    table = malloc(size*sizeof(struct list*));
    //Can be secured in the malloc simply if you use it the number of elements already known from a reading from a file.
    for(p=top; p ; p=p->next){
        table[n++] = p;
        if(n == size)
            table = realloc(table, (size+=16)*sizeof(struct list*));
    }
    qsort(table, n, sizeof *table, cmp);
    for(i = 0; i < n; ++i){
        int j;
        p = table[i];
        printf("%s %d %d ", p->name, p->id, p->numOfElements);
        for (j=0; j<p->numOfElements; j++){
            printf("%s ", p->pElements[j].name);
        }
        printf("\n");
    }
    free(table);
}
Другие вопросы по тегам