0

这段代码是我为学校作业做的二叉搜索树。

#include "binary_tree.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAXLEN 10


Node* create_tree() {

return NULL;

}

void insert_tree(Node** root, char* nname, char* number) {


    if (*root==NULL){
        Node* node = (Node *)malloc(sizeof(Node));

        strncpy(node->name , nname, MAXLEN);
        strncpy(node->number , number, MAXLEN);

        node->left = node->right = NULL;
        *root = node;
        return;

    }


    if (strncmp(*root->name, nname, MAXLEN)) {

        insert_tree(&(*root)->left, nname, number);

    } else {

        insert_tree(&(*root)->right, nname, number);
    }
}

void preorder(Node* node, int level){
    int i;
    if (node==NULL){
        //printf("null\n");
        return;

    }
    for (i = 0; i<level; i++) {
        printf("  ");
    }
    printf("%s %d\n", node->name, level);

    preorder(node->left, level + 1);
    preorder(node->right, level + 1);

}

这是我的完整代码。好吧,我删除了不必要的代码位,但这就是我需要知道的所有内容..

typedef struct t_node {
    char name[MAXLEN + 1];
    char number[MAXLEN + 1];
    struct t_node *left;
    struct t_node *right;

} Node;

这是我正在使用的节点类型。

在 insert_tree 处,插入一个节点即可。

但是当我使用 strncmp 时,它会出错。

“请求非结构或联合的成员”

root 不是节点结构吗?

我不明白为什么会出错。

4

1 回答 1

3

请参阅运算符优先级->,优先级在哪里*。您应该将(*root)->name其用作strncmp()通话的参数。

于 2015-05-15T12:57:31.613 回答