请求成员不是结构或联合,但它是一个结构

时间:2015-05-15 12:54:37

标签: c binary-search-tree strncmp

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

#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;

这是我正在使用的Node类型。

在insert_tree,插入一个节点就可以了。

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

  

“请求成员不是结构或联盟”

不是节点结构的根?

我不知道为什么会出错。

1 个答案:

答案 0 :(得分:3)

请参阅operator precedence,其中->优先于*。您应该使用(*root)->name作为strncmp()来电的参数。