我想寫一個BST
,但插入功能不起作用。調試它,我發現它沒有插入。我不能插入一個節點到bin搜索樹
/* Binary Search Tree (BST).demo */
#include <stdio.h>
#include <stdlib.h>
typedef struct treeNode{
int data;
struct treeNode* lChild;
struct treeNode* rChild;
} treeNode;
treeNode* createNode(){
treeNode *nNode;
nNode=(struct treeNode*)malloc(sizeof(treeNode));
nNode->data=0;
nNode->lChild=NULL;
nNode->rChild=NULL;
return nNode;
}
void insert(treeNode* rt,int idata)
{
if(rt==NULL){
treeNode* nNode;
nNode=createNode();
nNode->data=idata;
rt=nNode;
rt->lChild=NULL;
rt->rChild=NULL;
}else{
if(idata < rt->data)
insert(rt->lChild,idata);
else insert(rt->rChild,idata);
}
}
int main()
{
treeNode *root;
root=(treeNode*)malloc(sizeof(treeNode));
root->data=15;
root->lChild=NULL;
root->rChild=NULL;
insert(root,13);
if(root->lChild==NULL)
printf("root no l child\n");
// printf("root lchild data :%d",root->lChild->data);
return 0;
}
使用「根」的參考,當你將它作爲參數傳遞給插入功能。 –
但根本身是一個指針,是否需要引用? –
如果你不使用對'root'的引用,你會通過「value」將它傳遞給插入函數。在這種情況下,如果您正在創建一個新節點並將其分配給「根」(正如您在此處所做的那樣),則此更改不會反映在插入函數之外,從而導致錯誤行爲。 –