树 数值结构

#include <stdio.h>

typedef struct node{
	int data;
	struct node *lchild;
	struct node *rchild;
	int count;
}NODE,*ptr;

void insert(NODE *node,NODE *inode){
	if(node &&inode){
		if(node->data == inode->data ){
				printf("-%d-%d--\n",node->data,inode->data);
			node->count++;
		}else if(node->data <inode->data){
			printf("<<<<\n");
			if(node->lchild){
				printf("<<<<1111\n");
				insert(node->lchild,inode);
			}else{
				printf("<<<<222\n");
				node->lchild=inode;
			}
		}else {
			printf(">>>>>\n");
			if(node->rchild){
				printf(">>>>>11111\n");
				insert(node->rchild,inode);
			}else{
				printf(">>>>>2222\n");
				node->rchild=inode;
			}
		}
	}
}

void prtTree(NODE *node){
	if(node){
		printf("node->data:%d,node->count:%d\n",node->data,node->count);
		prtTree(node->lchild);
		prtTree(node->rchild);
	}else {
		return ;
	}
}

int main(void){
	NODE *node1 = (NODE * )malloc(sizeof(NODE));
	node1->data=4;
	node1->lchild=NULL;
	node1->rchild=NULL;
	
		NODE *node2 = (NODE * )malloc(sizeof(NODE));
	node2->data=3;
	node2->lchild=NULL;
	node2->rchild=NULL;
	
		NODE *node3 = (NODE * )malloc(sizeof(NODE));
	node3->data=2;
	node3->lchild=NULL;
	node3->rchild=NULL;
	
		NODE *node4 = (NODE * )malloc(sizeof(NODE));
	node4->data=10;
	node4->lchild=NULL;
	node4->rchild=NULL;
	
			NODE *node5 = (NODE * )malloc(sizeof(NODE));
	node5->data=112;
	node5->lchild=NULL;
	node5->rchild=NULL;
	
	insert(node1,node2);
	insert(node1,node3);
	insert(node1,node4);
	insert(node1,node5);
	prtTree(node1);
	
	
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值