c-移动指针以便按不同的顺序打印



我必须完成这个程序。

我有一个类似的文件

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(结构列表*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, "%st%dt%dt", 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, "%st", 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;
}

有人能帮我吗?

按临时存储在数组中的ID排序。

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);
}

相关内容

  • 没有找到相关文章

最新更新