0

是否可以打印节点数组?我需要在构建 AVL 树时显示它,但是每当我运行此代码时,程序就会崩溃。有什么替代方法吗?

     int k = 0;
    t = NULL;
    node* nodearray[32];
    for( j = 0; j < 33; j++)
    {
        printf ("Table %d \n", j+1);
        printf ("LineNum Left Data Right\n");
        t = Insert(j, a[j], t );

    for (k= 0 ; k < j ; k ++)
    {
         printf ("%5d %5d %5d %5d", nodearray[k]->num, nodearray[k]->left->data, nodearray[k]->data, nodearray[k]-> right ->data);
    }
}
4

1 回答 1

2

问题:

  1. nodearray未初始化 - 其中的指针具有不确定的值。取消引用它们会调用未定义的行为。

  2. for( j = 0; j < 33; j++)- 但您声明nodearray长度为 32 个元素。如果没有看到 的实现就很难判断Insert(),但可能你也有一个错误(你正在读/写超出数组的末尾)。

于 2013-05-10T19:58:33.583 回答