gpt4 book ai didi

c - 如何释放邻接链表分配的内存?

转载 作者:行者123 更新时间:2023-11-30 20:33:53 25 4
gpt4 key购买 nike

我想释放邻接链表内存这是我的数据结构和两个可以为图形分配内存的函数。如何释放分配的内存?感谢您的帮助

struct ListPoint {
int dest;
int weight;
struct ListPoint* next;
};
struct List {
struct ListPoint* head;
};
struct Graf {
int V;
struct List* array;
};
struct ListPoint* newAdjencyListPoint(int dest, int weight)
{
struct ListPoint* newPoint =
(struct ListPoint*)malloc(sizeof(struct ListPoint));
newPoint->dest = dest;
newPoint->weight = weight;
newPoint->next = NULL;
return newPoint;
}
struct Graf* createGraph(int V)
{
struct Graf* graf = (struct Graf*)malloc(sizeof(struct Graf));
graf->V = V;
graf->array= (struct List*)malloc(V * sizeof(struct List));
int i;
for (i = 0; i < V; ++i)
graf->array[i].head = NULL;
return graf;
}

最佳答案

以下代码可能就是您正在寻找的代码:

freeLinkedList(struct List list){
struct ListPoint *aux,*it = list.head;
while(it != NULL){ //free a node and go to the next one
aux = it->next;
free(it);
it = aux;
}
}
freeAdjList(struct Graf* adj_list){
for(int i=0;i<adj_list->V;i++) //free each linked list
freeLinkedList(adj_list->array[i]);
free(adj_list->array); //free the linked list array
free(adj_list); //free the adj matrix itself
}

关于c - 如何释放邻接链表分配的内存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43824178/

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