创建二叉树

*创建一颗树,树的叉等于所在层数
void create_tree(TreeNode **treenode, int max_data, int num)
{
 int i;
 LNode new_node;
 int test_data;
 
 printf("star : num = %d\n", num);

 if(max_data > 1)
 { 
//******************************************************************************************************************************* 
  *treenode = (TreeNode *)malloc(sizeof(TreeNode));//为节点开辟空间
  if(*treenode == NULL)
  {
   printf("the first malloc failed\n");
  }
 /*为数据结构中的指针分配空间 上层结构初始化完了在做下层结构 一层一层地来*/
 //*********************************************************************************************************************** 
  (*treenode)->listnode = (LNode *) malloc(sizeof(LNode) * num);//节点中的数据是一个链表,初始化这个链表
  if(((*treenode)->listnode) == NULL)
  {
   printf("the second malloc failed\n");
  }
  scanf("%d", &test_data);
  (*treenode)->listnode->data = test_data;
 

 //***********************************************************************************************************************
  (*treenode)->tree  = (TreeNode* *)malloc(sizeof(TreeNode*) * (num+1) );//初始化树杈 ,num+1为树杈的个数  

//********************************************************************************************************************************
  for(i=0; i<num+1; i++)//递归地以每个树杈为根,创建num+1棵树
  {
   create_tree(( &(*treenode)->tree[i] ), max_data-1, num+1);
  }
 }
//********************************************************************************************************************************
 else if(max_data == 1)//当到达最底层叶子节点时 :下面的树杈就为NULL了。
 {
  *treenode = (TreeNode *)malloc(sizeof(TreeNode));
  (*treenode)->listnode = (LNode *) malloc(sizeof(LNode));
  (*treenode)->tree = NULL;

  scanf("%d", &test_data);
  (*treenode)->listnode->data = test_data;
 }
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值