二叉树插入(只获取最后一项....)

时间:2015-07-16 06:12:31

标签: c data-structures

我正在尝试加载一个包含两个infor的文件,我想将它们添加到二叉树中。确定addToTree和printPreOrder函数没有问题,但我不知道为什么我只能打印(或者可能添加)文件中的最后一项。问题是什么?

newTree = createBinTree(&cmpInt, &destroyNode);
newRes = createRes();
while (fgets(buffer, 100, fp) != NULL)
{
    strcpy(newRes->name,strtok(buffer, ","));
    strcpy(newRes->food,strtok(NULL, ","));
    newRes->star = atoi(strtok(NULL, ","));
    addToTree(newTree, newRes);
}
printPreOrder(newTree, &printNode);

1 个答案:

答案 0 :(得分:2)

您总是添加到newRes的同一指针。阅读时会覆盖以前的newRes条目。您需要为正在阅读的每个对象调用createRes