大家好,我有两个结构:一个是密钥对,另一个是节点。
typedef struct {
char *key;
void *value;
} VL;
typedef struct node{
struct node *left;
struct node *right;
VL data;
} BST;
我将如何初始化节点结构并在其中添加 VL 结构?这是我到目前为止所拥有的:
// Create new node
struct node *temp = malloc(sizeof(node));
temp->left = NULL;
temp->right = NULL;
struct VL *vl = malloc(sizeof(VL));
vl->key = key;
vl->value = &value;
temp->data= *vl;
而且我还尝试了许多其他方法,例如将 temp->data.key 设置为 key 等,所有这些都返回错误。所以我来这里寻求帮助:)。
另外我将如何从节点获取数据?
char *key = (char *)5;
void *val = "hello";
// create node with this key/val pair and insert into the tree, then print
printf("key = %d; value = %s\n", (int)head->data.key, (char*)head->data.value);
这样就够了吗?
谢谢!