union node_u
{
struct
{
union node_u *left;
union node_u *right;
}internal;
double data[2];
};
int main(){
struct node_s s;
union node_u u;
union node_u node1;
union node_u node2;
union node_u node3;
node1.data[1] = 1;//数据
node1.internal.left = &node2;//左子树
node1.internal.right = &node3;//右子树
node2.data[1] = 2;
printf("%d",sizeof(node1));
printf("\n");
printf("%lf",node1.internal.left->data[1]);
return 0;
}
16
2.000000
PS F:\desktop\CSapp\3>
union结构中存储的不是互斥的俩个数据结构吗? 为什么union1中既可以存放数据节点 又可以存放子节点?
我认为给数据域赋值以后就不能对他的子节点的域进行操作,应当报错。
这个表示节点要么是叶子,只有数值,要么是树干,只有子节点,所以用union