gpt4 book ai didi

c - C 动态结构数组中的动态结构数组

转载 作者:行者123 更新时间:2023-11-30 16:50:41 25 4
gpt4 key购买 nike

我需要分配未知数量用户的数组,并且每个用户必须有未知数量选择的数组。所有数据均从 CSV 文件中读取。

到目前为止,我已经:

typedef struct wybor            //struct choice
{
char rozmiar_kawy[2];
char czy_z_mlekiem[4];
char ile_cukru[2];
char godzina[20];
}wybor;

typedef struct user
{
char id[5];
char imie[20];
wybor *tablica_wyborow; //dynamic array of struct choice
}user;


void odczyt_z_pliku(user **tab, int n); //reading from file csv
void godzina(user *kawa); //doesnt matter :p

int main()
{
int licznik = 0; //counter for number of users
user *tablica_userow; //dynamic array of struct users
tablica_userow = NULL;
setlocale(LC_ALL, "pl_PL");

odczyt_z_pliku(&tablica_userow, licznik);

getchar();
printf("%s", tablica_userow[0].tablica_wyborow[2].rozmiar_kawy); //check if it works
getchar();
return 0;
}

void odczyt_z_pliku(user **tab, int n)
{

int i = 0;
(*tab) = malloc(1*sizeof(*(*tab)));
tab[n]->tablica_wyborow = malloc(1*sizeof(*(tab[n]->tablica_wyborow)));
FILE *plik;
plik = fopen("users.csv", "a+");

//start reading from file and its working until...
fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);
i++;

tab[n]->tablica_wyborow = realloc(tab[n]->tablica_wyborow,(i+1)*sizeof(*(tab[n]->tablica_wyborow)));

fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);

i = 0;
n++;
*tab = realloc(*tab,(n+1)*sizeof(user)); //...now, here there is a memory writing location error

tab[n]->tablica_wyborow = malloc(sizeof(*tab[n]->tablica_wyborow));

fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);
i++;
tab[n]->tablica_wyborow = realloc(tab[n]->tablica_wyborow, (i + 1) * sizeof(*(tab[n]->tablica_wyborow)));

fscanf(plik, "%[^;] ; %[^;] ; %[^;] ; %[^;] ; %[^;] ; %s\n", tab[n]->id, tab[n]->imie, tab[n]->tablica_wyborow[i].rozmiar_kawy, tab[n]->tablica_wyborow[i].czy_z_mlekiem, tab[n]->tablica_wyborow[i].ile_cukru, tab[n]->tablica_wyborow[i].godzina);

fclose(plik);

}

我不知道为什么我无法正确重新分配用户数组。

我没有释放内存,因为当我尝试时它崩溃了。

最佳答案

您可以使用链表来读入数据。用户数据结构有一个指向用户选择的链接列表的指针。

如果您仍然想使用数组,现在可以计算用户数量,为其分配一个数组并用用户填充它。以同样的方式,您可以计算用户的选择数量并为其分配一个数组,然后填充它。

你的链表应该有一个void *成员,它将为用户存储一个指向单独数据结构的指针,这样你就可以将用户数据结构的指针从链表移动到你的链表中。数组。

用户数据结构有一个用于用户选择的成员wybor *tablica_wyborow;。您可以维护一个链表,在读入数据时保存用户的选择,然后,一旦读取了所有用户的选择,您就可以对它们进行计数并为其分配一个数组,并复制选择数据(通过值或指针)进入其中。

完成所有操作后,释放链接列表,因为您不再需要它们。

或者,您可以读取文件进行计数,然后重新处理它。但这会带来计算单个用户选择的问题。

关于c - C 动态结构数组中的动态结构数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42113880/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com