二叉查找树初始化与插入算法

学算法的时候自己写的

#include<stdio.h>
#include<stdlib.h>
typedef struct Node
{
 int key;
 struct Node* right;
 struct Node* left;
}BSearchNode;

//-------------------------------------------------------
BSearchNode* Initial()
{
 BSearchNode* root;
 root=(BSearchNode*)malloc(sizeof(BSearchNode));
 root->key=rand();
 root->left=NULL;
 root->right=NULL;
 return root;
}

//-------------------------------------------------------
void InsertNode(BSearchNode* root,int n)
{
 if(root==NULL)
 {
  printf("error!");
 }
 if(n<=root->key)
 {
  if(root->left)
  {
   InsertNode(root->left,n);
  }
  else
  {
   BSearchNode* p=(BSearchNode*)malloc(sizeof(BSearchNode));
   root->left=p;
   p->key=n;
   p->left=NULL;
   p->right=NULL;

 //这里的return应该是可以直接跳出整个递归程序的
   return;
  }
 }
 if(n>root->key)
 {
  if(root->right)
  {
   InsertNode(root->right,n);
  }
  else
  {
   BSearchNode* p=(BSearchNode*)malloc(sizeof(BSearchNode));
   root->right=p;
   p->key=n;
   p->left=NULL;
   p->right=NULL;
   return;
  }
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值