我正在尝试释放我的 trie 上的指针。这是我的特里结构
struct trie
{
int x;
trie *next[26];
};
trie *head;
trie *tmp;
这是我使用 dfs 的解除分配功能
void deallocate(trie *cur)
{
for (int a=0; a<=25; a++)
{
if (cur->next[a] != NULL)
{
tmp = cur->next[a];
cur->next[a] = NULL;
deallocate(tmp);
}
}
free(cur);
}
这是我的头部初始化函数
void init()
{
head = new trie;
head->x = 0;
for (int a=0; a<=25; a++)
{
head->next[a] = NULL;
}
}
在程序结束后我打电话给deallocate(head);
我对指针的东西真的很陌生,我的 deallocate 函数有什么问题吗?谢谢
更改了数组大小并被接受:)看来问题不在于指针:)谢谢大家